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内 容 简 介 
本 书 通过 展示 一 个 完整 网 站 的 设计 和 实现 过 程 , 详细 地 介绍 动态 网 页 设计 和 制作 的 技术 和 相关 理 
论 。 全 书 共 8 章 ， 主 要 包括 动态 网 站 设计 概述 、 动 态 网 站 编程 环境 、 网 站 主页 设计 与 PHP 基础 、 网 
站 计数 器 设计 与 PHP 文件 访问 、 会 员 注册 和 管理 设计 与 数据 获取 .网 上 社区 设计 与 PHP 数据 库 访问 、 
网 上 购书 与 PHP 面向 对 象 技术 、 网 站 优化 与 PHP 的 高 级 功能 。 本 书 案例 以 模块 的 方式 加 以 组 织 , 包 
括 网 站 的 整体 设计 、 主 页 的 实现 、 网 站 计数 器 、 网 上 社区 、 会 员 管理 系统 、 网 上 购物 系统 、PHP 的 
高 级 功能 。 案例 以 可 视 化 开发 工具 为 平台 , 既 关注 高 效率 的 实现 技术 , 又 注重 理论 知识 的 系统 和 完整 ， 
更 关注 读者 的 学 习 体验 。 
本 书 内 容 系统 全 面 , 案例 典型 实用 , 讲述 直观 详尽 , 非常 适合 动态 网 页 设计 与 制作 的 初学 者 使 用 ， 
还 可 作为 高 等 院 校 教学 用 书 和 “实用 型 ”人 才 培 训 用 书 。 
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第 1 版 前 言 


随 着 Internet 技术 及 其 应 用 的 不 断 发 展 ， 网 络 对 人 们 生活 、 学 习 和 工作 的 影响 越 来 越 大 。 
于 核心 地 位 的 Web 技术 也 逐渐 渗透 到 各 个 领域 ， 从 企业 网 站 、 个 人 博客 到 电子 商务 、 
政务 工程 的 建设 都 离 不 开 网 页 设计 与 制作 技术 。 这 些 网 站 除了 要 展示 常规 的 信息 以 外 ， 
也 是 实时 更 新 、 动 态 变化 的 内 容 ， 因 此 需要 在 HTML、CSS 和 JavaScript 的 基础 上 进 
使 用 Web 新 技术 ， 如 ASP、JSP、PHP、Ajax。 可 见 ， 本 书 是 《网 页 设计 和 制作 案例 









































作为 全 球 普 及 的 互联 网 开发 语言 之 一 的 PHP 从 1994 年 诞生 至 今 已 被 2000 多 个 网 站 采 





。 国 外 知名 互联 网 公司 Yahoo!. Google. Lycos. Youtube -和 中 国 知 名 网 站 新 浪 、 百 度 、 
W. TOM 等 均 是 PHP 技术 的 经 典 应 用 。 





iiti PHP 技术 的 成 熟 和 完善 , 它 已 经 从 一 种 针对 网 络 开 发 的 计算 机 语言 发 展 成 为 一 个 


合 于 企业 级 部 署 的 技术 平台 。IBM、Cisco、 西 门 子 、Adobe 等 公司 均 选 用 了 PHP 技术 ， 


正 逐 渐 成 为 互联 网 开发 前 





流 语言 。2005 年 7 月 ，PHP 5.0 的 诞生 标志 着 PHP 进入 一 





MAR. Zend 引擎 的 采用 、 完 备 对 象 模型 改进 的 语法 设计 使 得 PHP 成 为 一 个 设计 完 


真正 具有 面向 对 和 象 能 力 的 脚本 语言 

相对 于 ASP(.NET) 和 JSP( 或 Java 开发 的 B/S 程序 ) ”PHP 不 需要 太 多 的 类 库 ， 不 需要 
但 有 些 策 拙 的 开发 平台 ; 一切 都 能 给 人 简单 和 清新 的 感觉 。 更 重要 的 是 ， 基 于 PHP 的 
库 (动态 库 ) 的 开发 可 以 让 开发 者 全 面 了 解 系统 功能 是 如 何 一 步 步 用 代码 实现 的 ， 不 像 
控件 、Java 的 类 库 ， 虽 然 给 开发 者 带 来 了 方便 ， 却 屏蔽 了 功能 上 有 具体 的 实现 细节 ， 
初学 者 来 说 是 不 利 的 ， 容 易 对 控件 和 类 库 产 生 依赖 而 不 能 独立 开发 。 

前 使 用 PHP 的 工程 师 有 数 百 万 之 多 ，PHP 的 开源 特性 使 开发 者 可 获得 更 多 资源 ， 几 
有 开发 中 可 能 遇 到 的 问题 在 Internet 上 都 能 找到 解决 的 办 法 。 随 着 技术 的 不 断 发 展 , 还 
现 新 的 方法 与 优化 的 方案 ， 甚 至 在 PHP 中 融合 了 其 他 Web 语言 的 优点 ， 为 PHP 注入 
的 活力 。 本 书 能 为 刚 接触 PHP 的 新 人 开辟 一 条 捷径 。 

本 书 是 一 本 在 具有 静态 网 页 设计 和 制作 的 基础 上 全 面 介绍 PHP 动态 网 页 编程 技术 的 教 
通过 学 习 本 书 ， 学 习 者 可 掌握 动态 网 站 的 开发 方法 和 过 程 ， 学 会 动态 网 站 中 常见 的 模 
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H, 如 网 上 论坛 、 会 员 管理 或 网 上 商城 等 的 设计 技术 ; 学 会 使 用 网 站 发 布 和 维护 的 技巧 。 


本 书 的 特点 


对 网 
的 设 














(1) 案例 驱动 。 本 书 围绕 一 个 完整 网 站 案例 展示 架构 网 站 的 制作 方法 和 开发 过 程 : 先 
站 进行 规划 和 版 式 设计 ， 来 认识 网 页 设计 的 过 程 、 方 法 和 工具 ; 再 依次 通过 各 个 模块 
计 和 制作 展开 对 PHP 语言 的 解析 ， 让 学 习 者 体验 网 页 制作 的 过 程 和 环境 ， 从 而 避免 任 
动 中 重 制作 轻 设计 、 重 视 如 何 实现 各 个 技术 要 点 而 忽略 系统 整体 结构 的 不 足 。 

D 技术 实用 。 本 书 强调 网 站 开发 的 全 过 程 ， 以 工程 开发 的 方法 组 织 教材 体系 ， 涉 及 
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的 技术 是 目前 网 站 建设 中 的 关键 技术 ， 实 用 性 强 ， 对 案例 略 加 改变 就 可 直接 移植 到 其 他 网 
站 的 建设 和 开发 中 。 

(3) 教学 便利 。 本 书 采用 模块 化 开发 方法 ， 注 重 代码 解读 ， 能 使 学 习 者 不 必 完 全 按照 
章节 顺序 而 选择 最 关注 的 内 容 或 与 同学 合作 学 习 ， 这 既 符 合 人 们 认识 事物 的 心理 过 程 ， 也 
具有 实践 的 操作 直观 性 与 理论 的 系统 完整 性 ， 能 充分 调动 学 习 者 的 学 习 积 极 性 和 主动 性 ， 
给 教师 提供 更 大 的 教学 设计 空间 。 


本 书 体例 











本 书 体例 包含 以 下 项 目 。 


Sg am 由 此 体现 各 章 的 学 习 目 
标 及 组 织 相应 的 学 习 材料 。 


Tum 
Manen 一 和 的 从 中 可 体验 网 页 设计 的 方法 。 


SÉ anon 一 体现 各 章 的 学 习 目标 。 


1 


预备 知识 kp AAMEN Ro X x js 
& AICmin 


9 css. 二 案例 涉及 的 CSS epi RUM CRI. 








V pupa 一 一 案例 涉及 的 PHP 代码 编写 过 程 及 详细 代码 。 
QD, PHP 技术 角度 关注 的 要 点 内 容 。 


ca D 

un 对 示意 图 或 函数 功能 的 解释 。 
QE ooo. 
VANE ———— m 


p 
SEEL 从 学 习 者 角度 关注 的 技术 要 点 。 


QUEE UAE, VEENDA. 





罕 例 扩展 一 对 案例 所 涉及 的 技术 和 策略 进一步 扩展 和 补充 的 案例 。 


er 
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代码 解读 对 案例 中 所 涉及 的 PHP 代码 的 分 析 。 

技术 要 点 ”由 案例 引出 的 PHP 语言 要 点 。 

本章 总 结 _ ”概要 地 总 结 了 本 章 所 述 的 内 容 。 
e BRD prki AEAEE e 


实践 项 目 由 学 习 者 完成 的 不 固 和 扩展 相关 知 jg 的 实验 项 目 。 


EN k 
, CR 
相关 资源 —r d 


本 书 案例 Y 


A 








本 书 的 案例 是 网 上 书店 网 站 。 通过 对 i A 一 个 简易 的 

网 上 书店 ， 实 现 了 商品 查询 、 Sn 上 社区 、 购 物 和 结算 等 功能 。 
ON XX 
V E 
本 书 作 者 E. p is - X AR 
ns A 

本 书 由 房 爱 莲 主编 。 te INT 张 开 飞 、 盛 晓 勇 和 分 萍 也 参与 了 
案例 和 部 分 章 藻 内容 的 讨论 ， 在 此 对 大 家 辛勤 工作 表示 衷心 的 感谢 ! 
限于 编者 水 平 ; 书 中 难免 存在 朴 漏 和 不 妥 之 处 ， 有 恳请 广大 读者 提出 宝贵 意见 ， 联 系 信 
箱 : ailianfícitiz.net. 
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第 2 版 前 言 


随 着 PHP 技术 的 不 断 更 新 和 发 展 , 本 书 第 1 版 的 内 容 有 些 地 方 显然 已 经 过 时 了 。 因此 ， 
为 了 跟 进 技术 的 发 展 ， 这 次 修订 中 对 许多 技术 做 了 较 大 的 更 新 和 改动 。 

(1) 本 次 修订 对 PHP 环境 安装 与 配置 做 了 大 幅度 的 改动 ， 重 新 编写 了 第 2 章 ， 给 出 了 
当前 最 新 的 环境 配置 和 安装 说 明 。 对 比 第 1 版 ， 也 能 了 解 PHP 技术 发 展 的 脉络 。 

(2) 本 次 修订 提供 了 多 种 连接 MySQL 数据 库 的 方式 。 PHP 对 MySQL 数据 库 的 连接 提 
供 了 多 种 方式 ， 为 了 照顾 到 初学 者 或 习惯 于 面向 过 程 的 读者 ， 本 版 做 了 如 下 处 理 : 

€ 在 第 5 章 中 ， 仍 然 保 持 了 原 有 的 MySQL 扩展 。 

€ 在 第 6 章 的 bbs 部 分 使 用 了 MySQLi 扩展 中 面向 过 程 的 方式 ， 这 样 能 很 自然 地 从 
MySQL 扩展 过 滤 到 当前 的 MySQLi 扩展 。 

* 在 第 6 章 的 chat 部 分 使 用 了 MySQLi 扩展 中 面向 对 象 的 方式 ， 一 方面 能 通过 与 
MySQLi 扩展 中 面向 过 程 对 比 学 习 ， 另 一 方面 也 为 第 7 章 面向 对 象 的 技术 做 好 铺垫 。 

G) 本 次 修订 还 对 其 他 章节 的 案例 和 技术 做 了 修订 ， 对 相关 技术 要 点 重新 编写 了 示例 。 

这 样 处 理 希 望 能 方便 教师 和 学 生 经 历 从 熟悉 到 未 知 、 以 旧 引 新 、 逐 步 深入 的 过 程 ， 获 
得 自然 的 教学 体验 。 

从 本 书 第 1 版 的 读者 反馈 来 看 ， 读 者 对 案例 驱动 学 习 比 较 认可 。 本 书 第 2 版 保持 了 这 
一 风格 。 毕 竞 ， 从 实践 体验 到 理论 提升 已 经 成 为 学 习 的 一 种 有 效 途 径 。 本 书 第 2 版 以 网 上 
书店 网 站 为 案例 ， 通 过 对 网 士 商城 的 分 析 、 规 划 和 设计 ， 展 示 了 一 般 动 态 网 站 开发 的 一 个 
典范 ， 对 独立 开发 动态 Web 系统 有 一 定 的 参考 和 借鉴 作用 。 

本 书 第 2 版 由 房 爱 莲 担 任 主编 ， 尹 敏 : 张 倩 参与 了 本 书 的 编写 工作 。 

限于 编者 水 平 ， 书 中 难免 存在 朴 漏 和 不 妥 之 处 ， 奶 请 广大 读者 提出 宝贵 意见 ， 联 系 信 
箱 : ailianf@citiz.net. 
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通过 本 章 的 学 习 ， 能 够 使 读者 : 
(1) 知道 动态 网 站 所 具有 的 特点 。 
(2) 了 解 动态 网 站 的 运行 机 制 。 
(3) 掌握 动态 网 站 的 规划 内 容 。 
(4) 了 解 动态 网 站 的 开发 流程 。 


FIRA 


本 章 为 读者 准备 了 以 下 学 习 资 源 : 

(1) 体验 案例 :- 展示 “动态 网 站 的 特点 ”明确 静态 和 动态 网 站 的 不 同 ， 对 应 本 章 的 1.1 节 。 

(2) 技术 要 点 : 描述 “动态 网 站 的 运行 机 制 ” 对 应 本 章 的 1.2~1.4 节 。 其 中 的 图 示 给 
出 了 相关 技术 的 说 明 实例 ， 同 时 给 出 了 当前 一 些 资源 学 习 网 站 。 

(3) 实验 项 目 : 要 求 参考 相关 网 站 来 巩固 技术 要 点 的 内 容 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 : 

(1) 浏览 体验 案例 ， 观 察 这 些 动态 网 站 的 特点 ， 与 学 校 信息 发 布 的 网 站 作 比 较 。 

(2) 认真 阅读 相关 的 技术 要 点 ， 明 确 动 态 网 站 的 运行 机 制 和 规划 要 素 。 

(3) 通过 浏览 相关 网 站 ， 认 识 动态 网 站 开发 的 过 程 和 方法 。 

学 习 过 程 中 ， 提 倡 结对 或 3 人 组 成 学 习 小 组 ， 采 取 分 工 合作 ， 交 流 学 习 的 心得 经 验 和 
体会 ， 也 能 培养 协作 精神 ， 会 得 到 更 多 的 收获 。 
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本 章 案例 从 体验 3 个 典型 的 动态 网 站 (W3school 网 、 中 国 工商 银行 网 、 新 浪 网 ) 中 认识 
动态 网 站 的 特点 ， 并 通过 对 本 书 案例 网 站 的 规划 了 解 设计 和 制作 动态 网 站 的 过 程 和 方法 。 











1:4 态 网 站 的 特点 


A. 


1. 体验 ASP 制作 的 网 站 < 
(1) 在 浏览 器 的 地 址 栏 中 输入 http://www.w3school.c ex.html， 进 入 如 图 1.1 所 
示 的 W3school 首页 。 ; x»! 
NN 


e > O | wchoolcomen/nomhnl : ^ 2*| 三 WA. 
A BLOA9 


Nor - 
HTML /CSS JavaScript PAS N $ ASP.NET mG yh Services Web Building 





| 一 图 1.1 — 
(2) dti ail “HTML/CSS” rs 进入 图 12 所 示 的 页 面 。 


HTML / CSS JavaScript Server Side ASP.NET XML Web Services Web Building 


EIIS (DUE 
e HTML 系列 教程 m 
| | 


1.2 链接 “HTML/CSS” 的 网 页 





G) 这 个 网 页 的 扩展 名 是 .asp, 说 明 网 站 中 使 用 了 ASP 动态 网 页 技术 。 仔细 观 察 页 面 并 
体验 网 站 中 的 搜索 和 测验 模块 。 


2. 体验 JSP 制作 的 网 站 


(1) 在 浏览 器 的 地 址 栏 上 输入 http:/www.icbc.com.cn/ICBC/default.htm， 进 入 如 图 1.3 
所 示 的 中 国 工商 银行 网 站 的 首页 。 
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图 1.3 中 


[t] 





工商 银行 网 站 的 首页 








(2) 单 击 左 侧 的 “个 人 网 上 银行 ”按钮 ， 进 入 如 图 1.4 所 示 的 金融 通道 页 面 ， 同 时 地 址 
栏 上 显示 的 URL 为 http://mybank.icbc.com.cn/icbc/perbank/index.jsp。 可 见 这 个 网 页 的 扩展 
名 是 jsp， 说 明 网 站 中 使 用 了 JSP 动态 网 页 技术 。 

(3) 观察 页 面 中 包含 的 网 页 元 素 。 





ICBC( 国 中 国 工商 银行 








图 1.4” 中 国 工商 银行 的 金融 通道 页 面 
3. 体验 PHP 制作 的 网 站 
(1) 在 浏览 器 的 地 址 栏 二 输入 http://www.sina.com.en/, 进入 如 图 1.5 所 示 的 新 浪 网 首页 。 


DTE Wo 
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图 1.5 新 浪 网 的 首页 


(2) 选择 导航 栏 上 的 “博客 ”中 的 “博客 评论 ”选项 后 ， 进 入 如 图 1.6 所 示 的 “新 浪 博 
客 ” 登 录 页 面 , 同时 地 址 栏 上 显示 的 URL 为 http://login.sina.com.cn/signup/signin.php?entry= 
blog&r-http?63A?62F?62Fi.blog.sina.com.cn?62Fblogprofile?o2Fprofilecommlist.php9?63Ftype?6 
3Dl1&from-referer:http?63A?62F962Fi.blog.sina.com.cn?62Fblogprofile?62Fprofilecommlist.php 
%3Ftype%3D1。 注 意 到 网 页 文件 的 扩展 名 及 其 后 面 的 “? ”和 一 系列 由 “%” 分 割 的 代码 。 
(3) 图 1.6 所 示 网 页 的 扩展 名 为 .php， 说 明 网 站 中 使 用 了 PHP 动态 网 页 技术 。 尝 试 在 文 


本 框 中 输入 登录 名 和 密码 后 ， 单 击 “登录 ”按钮 ， 观 察 页 面 的 变化 。 
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动态 网 站 的 特点 


O) 动态 网 站 以 数据 库 技术 为 基础 ， 可 以 大 大 降低 网 站 维护 的 工作 量 。 

D 动态 网 站 可 以 实现 更 多 的 功能 ， 如 用 户 注册 和 登录 、 用 户 管理 、 订 单 管理 等 。 

O) 开发 动态 网 站 要 使 用 服务 器 端 执行 的 脚本 语言 ， 如 ASP、JSP 或 PHP。 

(4) 动态 网 页 中 的 “2?” 提 供 了 一 种 数 握 待 送 方式 ， 实 现 了 网 页 交互 功能 

(5) 动态 网 页 实际 上 并 不 是 独立 存在 于 服务 器 上 的 网 页 文件 ,只 有 当 用 户 请 求 时 服务 器 才 返 回 一 
个 完整 的 网 页 MS v Sc 


动态 网 站 和 静态 网 站 有 何 区 别 ? 


(1) 动态 内 站 可 以 实现 静态 网 站 所 实现 不 了 前 功能 ， 如 聊天 室 、 论 坛 、 搜 索 等 。 

(2) 静态 网 站 的 源 代码 是 完全 公开 的 ， 任 何 浏览 者 都 可 以 非常 轻松 地 得 到 其 源 代码 。 动态 网 站 的 
源 代码 放 在 服务 器 上 ， 在 浏览 器 上 查看 到 的 源 代码 是 转换 后 的 代码 。 这 样 要 修改 动态 网 站 的 源 代码 
都 必须 在 服务 器 上 进行 ， 显 然 保 密 性 能 比较 优越 

(3) 动态 网 站 可 以 直接 使 用 数据 库 ， 还 可 以 调用 远程 数据 ， 并 通过 数据 源 直 接 操作 数据 库 ; 而 静 
态 网 站 只 能 使 用 表格 实现 动态 网 站 数据 库 表 中 的 部 分 数据 的 显示 ， 不 能 操作 数据 库 表 . 

(4) 动态 网 站 的 开发 语言 是 编程 语言 ， 如 PHP、JSP、ASP/ASPNET。 而 静态 网 站 只 能 用 HTML 
开发 ， 这 只 是 一 种 标记 语言 ， 显 然 不 能 实现 程序 的 功能 . 动态 网 站 可 以 实现 程序 的 高 效 快速 性 能 ， 
而 静态 网 站 没有 高 效 快速 可 言 。 

(5) 动态 网 站 本 身 就 是 一 个 可 以 实现 程序 几乎 所 有 功能 的 系统 ， 而 静态 网 站 则 不 是 ， 它 只 能 实现 
文本 、 图 片 、 音 视频 等 信息 的 展现 

(6) 静态 网 站 的 网 页 以 .html、.htm 为 扩展 名 。 而 动态 网 站 的 网 页 常 以 .php、.asp(aspx) 和 .jsp 等 为 
扩展 名 。 

(7) 静态 网 页 的 内 容 是 固定 的 ,修改 和 更 新 都 必须 通过 专用 的 网 页 制作 工具 。 动态 网 页 可 通过 脚 
本 将 网 站 内 容 动 态 存储 到 数据 库 ， 用 户 访问 网 站 是 通过 读 取 数 据 库 来 动态 生成 网 页 的 方法 实现 的 。 
即 静 态 网 页 和 动态 网 页 最 大 的 区 别 ， 就 是 网 页 是 固定 内 容 还 是 可 在 线 更 新 内 容 
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1.2 ”动态 网 站 的 运行 机 制 
通过 体验 动态 网 站 ， 可 见 动态 网 站 包含 了 用 户 、 用 户 浏览 信息 的 客户 端 、 存 放 网 页 和 


网 站 资源 的 Web 服务 器 ， 以 及 存储 数据 的 数据 库 服务 器 等 要 素 。 网 页 中 的 程序 代码 可 以 在 
客户 端 处 理 ， 也 可 以 在 服务 器 端 处 理 。 动 态 网 站 各 要 素 间 的 关系 如 图 1.7 所 示 。 




















| | -ee 读 取 数据 


= 
Web 服 务 器 存 入 数据 
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1.2.1 域名 


域名 是 网 站 中 网 页 在 互联 网 上 的 名 称 ) 也 是 企业 在 网 上 的 商标 ， 还 是 解决 地 址 对 应 问 
题 的 一 种 方法 。 用户 向 Web 服务 器 发 出 的 页 面 请 求 就 是 通过 在 浏览 器 的 地 址 栏 输 入 网 站 的 
域名 和 对 应 的 首页 实现 的 。 1。 D 

域名 具有 如 下 格式 的 结构 : 2 

主机 名 .网 络 名 .机 构 名 . 国 别 代码 SR 


(1) 机 构 名 : 与 国 别 代码 合 称 为 顶级 域名 常见 的 有 以 下 几 种 : 
QD com: 商业 机 构 ， 任 何人 均 可 注册 。 

Gorg: 各 种 组 织 ， 非 营利 的 任何 人 。 

G edu: 教育 机 构 。 

@ net; 网 络 组 织 ， 任 何人 均 可 注册 。 

@@ al: 科研 机 构 。 

© gov: 政府 部 门 。 

(2) 国 别 或 区 域 代码 ， 如 cn( 中 国 )、jp( 日 本 )、uk( 英 国 )。 




















命名 域名 应 该 遵循 的 规则 
(D 不 区 分 大 小 写 。 
O 包含 字符 : 26 个 英文 字母 、10 个 数字 ， 也 允许 使 用 中 文 。 
Q) 每 部 分 不 超过 26 个 字符 . 


(4) 用 “.” 分 割 各 个 部 分 。 
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本 书 案例 的 域名 为 wuyabook.com.cn. 

1.2.2 网 页 


网 页 (Web Page) 一 般 由 文字 、 图 片 、 超 链接 等 组 成 另外， 声音 、 视 频 、 动 画 等 多 媒 
体 元 素 可 以 为 网 页 增添 丰富 的 色彩 和 动感 效果 。 

根据 网 页 内 容 更 新 的 方式 不 同 ， 网 页 可 分 为 静态 网 页 与 动态 网 页 。 

在 静态 网 页 上 ， 也 可 以 出 现 各 种 动态 的 效果 ， 如 GIF 格式 的 动画 、Flash 格式 的 
动画 和 视频 、 滚 动 信息 等 ， 但 这 些 “ 动 态 效果 ”只 是 视觉 上 的 ， 与 动态 网 页 是 不 同 的 

动态 网 页 不 能 直接 由 浏览 器 解释 显示 。 动 态 网 页 的 运行 机 制 示意 如 图 1.8 所 示 。 


























图 1.8 动态 网 页 的 运行 机 制 

客户 端 : 与 Internet 连接 、 安 装 了 浏览 器 以 供用 户 浏览 网 页 的 计算 机 终端 。 在 客户 端 ， 
可 以 直接 将 HTML 文件 显示 在 浏览 器 上 。 有 时 直接 把 客户 端 称 为 浏览 器 。 

服务 器 : 一 台 存 储 所 有 网 页 及 相关 资源 数据 的 计算 机 。 服 务 器 还 有 一 层 含义 是 指 处 理 
从 访问 者 发 送 到 网 页 请 求 的 各 类 软件 。 

含有 服务 器 端 处 理 程序 语言 编写 的 网 页 : 使 用 服务 器 端 处 理 的 脚本 语言 编写 的 代码 可 
以 嵌入 HTML 中 的 网 页 文件 ， 它 不 能 在 客户 端 直 接 显示 ， 必 须 由 服务 器 端 解析 ， 生 成 客户 
端 能 显示 的 HTML 文件 。 

HTML 文件 ， 能 直接 在 客户 端 显示 的 文本 文件 。 














客户 端 技术 与 服务 器 端 技术 
实现 动态 网 页 的 技术 有 两 种 : 客户 端 技术 和 服务 器 端 技术 。 


客户 端 技术 : 由 脚本 语言 JavaScript、VBScript 等 编写 的 各 种 程序 和 遥 辑 控制 ， 实 现 了 某 些 交互 
的 网 页 。 

服务 器 端 技 术 : 通过 ASP, PHP. JSP 等 语言 编写 能 与 远程 主机 上 的 数据 库 进行 信息 处 理 ， 从 而 
实现 客户 端 与 服务 器 之 间 的 动态 和 个 性 化 的 交流 和 互动 的 网 页 。 





1.23 浏览 器 











浏览 器 的 作用 是 通过 HTTP 复原 并 显示 来 自 Web 服务 器 的 信息 。 目 前 常用 的 有 Internet 


Oy 
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Explorer, Netscape, Opera, Firefox 等 。 
要 扩展 显示 HTML 文档 ， 还 需要 浏览 器 插件 ， 如 支持 视频 和 音频 播放 的 Media Player 
和 Real Player， 支 持 PDF 文件 阅读 的 Acrobat Reader 等 。 

















html、htm 与 shtml 


html 是 由 HTML (Hyper Text Mark-up Language， 超 文本 标记 语言 ) 编 写 的 文件 ， 可 包含 由 浏览 器 
直接 解释 而 不 需要 服务 器 解析 的 脚本 。 


htm 与 html 没有 本 质 意义 的 区 别 ， 只 是 为 了 满足 DOS 的 8.3 文件 命名 规范 ， 

shtml 是 一 种 基于 SSI (Server Side Include， 服 务 器 端 包含 指令 ) 技 术 的 文件 。 当 有 服务 器 端 可 执 
行 脚本 时 被 当 作 一 种 动态 编程 语言 来 看 待 ， 就 如 asp. jsp 或 者 php 一 样 . 当 shtml 或 者 shtm 中 不 包 
含 服务 器 端 可 执行 脚本 时 ， 其 作用 同 html 或 者 htm. Y 





12.4 服务 器 


根据 动态 网 a E. 服务 器 主要 分 为 Web 服务 器 和 数据 库 服 
务 器 。 

目前 , 较为 流行 的 Web 服务 器 有 Nes IIS 和 Tomcat 等 。 数 据 库 服务 器 有 MySQL. 
SQL Server 和 Oracle 等 。 

对 于 网 站 中 的 数据 管理 ， 主要 祝 用 文件 系统 和 关系 叛 所 库 。 

文件 系统 由 文件 和 目录 组 成 其 优点 是 一 目 Te 缺点 是 当 数据 多 至 需要 分 门 别 关 时 ， 

造成 重复 存储 和 读 取 不 使 。 ” 

关系 数据 库 指 用 数据 表 的 形式 存储 和 组 织 数据 ， 合用 SQL 能 有 效 地 查询 数据 。 

例如 ， 计 算 机 配件 销售 数据 库 包 含 了 3 张 数 据 表 ， 如 图 L9 所 示 。 





订单 Ah 





- LII 
窗户 | 














图 1.9 计算 机 配件 销售 数据 库 包 含 了 3 张 数 据 表 
要 查询 张 三 的 订单 ， 可 通过 SQL 语句 实现 : 
select * from 订单 where 客户 编号 =1 


本 书 案例 中 ， 采 用 在 Windows 操作 系统 上 安装 Apache 服务 器 端 程序 ， 使 用 MySQL 
数据 库 管 理 图 书 和 用 户 数据 ， 使 用 文件 系统 构建 网 站 计数 器 。 
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1.3 动态 网 站 的 规划 


动态 网 站 的 建设 一 般 经 过 以 下 步骤 。 

(1) 前 期 调查 。 了 解 市 场 状 况 ; 分 析 市 场 特点 、 竞 争 者 和 访问 者 ， 分 析 建 网 能 力 等 。 

(2) 网 站 规划 。 确 定 网 站 目标 和 定位 ， 分 析 网 站 所 要 实现 的 主要 功能 和 规划 网 站 内 容 等 。 
(3) 网 站 总 体 设计 。 确 定 实现 网 站 的 技术 解决 方案 等 。 

(4) 网 站 实现 。 对 网 站 的 界面 、 交 互 和 程序 等 进行 制作 和 设计 。 
(5) 网 站 测试 及 文档 编写 。 编 制 测试 网 站 的 用 例 和 相关 的 文档 。 
(6) 网 站 发 布 和 维护 。 把 经 测试 确认 的 网 站 发 布 到 服务 器 供用 户 使 用 并 维护 其 正常 运行 。 
此 可 见 ， 网 站 规划 是 网 站 建设 的 一 个 关键 环节 。 这 里 从 网 站 的 类 型 、 主 题 、 结 构 、 
内 容 和 风格 等 儿 个 方面 对 本 书 案例 网 站 进行 规划 与 设计 。 


1.8.1. 确定 网 站 的 类 型 


确定 网 站 的 类 型 有 利于 对 网 站 的 功能 定位 ， 也 有 利于 确定 网 站 面向 的 用 户 群 。 
为 了 更 方便 地 维护 动态 网 站 ， 需 要 设置 专职 人 员 人 负责 对 数据 的 更 新 、 备 份 等 维护 。 因 
此 ， 在 动态 网 站 中 除了 供 普通 客户 使 用 的 前 台 界 面 外 ， 都 有 一 个 后 台 界面 供 管理 员 使 用 。 
本 书 案例 定位 于 电子 商务 网 站 ,实现 B2C 的 服务 模式 。 在 前 台 , 具有 书目 浏览 、 选 购 、 
购物 车 管理 、 订 单 查 询 等 用 户 前 台 功 能 ,还 有 管理 员 对 图 书 、 图 书 类 别 、 订 单 管理 等 后 台 
功能 。 同 时 为 了 加 强 与 用 户 的 交互 < 还 设置 了 登录 与 注册 > 会 员 管理 、 聊 天 室 和 顾客 留言 
等 功能 模块 。 





































































































常见 的 动态 网 站 类 型 
常见 的 动态 网 站 类 型 如 表 1.1 所 示 。 
表 1.1 常见 的 动态 网 站 类 型 


动态 管理 功能 
集合 众多 内 容 ， 提 供 多 样 服务 ， 尽 可 能 地 成 为 - "e 
网 络 用 户 上 网 的 首先 内 容 管理 、 栏 目 信息 管理 


利用 计算 机 技术 、 网 络 技术 和 远程 通信 技术 ，| 商品 管理 、 购 物 车 管理 、 会 


电子 商务 网 站 实现 整个 商务 过 程 电子 化 、 数 字 化 、 网 络 化 | 员 管理 、 订 单 管理 、 在 线 交 
B2B( 商 家 对 商家 )、B2C( 商 家 对 个 人 客户 ) 易 、 商 品 配送 管理 

报社 、 杂 志 社 、 广 播 电台 、 电 视 台 ， 是 为 树立 | 信息 发 布 、 电 子 出 版 、 客 户 
自己 的 网 上 形象 而 建设 的 在 线 咨询 、 网 站 管理 

企 事业 单位 为 实现 办 公 自 动 化 而 建立 的 内 部 | 事务 管理 、 人 力 资源 管理 、 
网 站 财务 资产 管理 、 网 站 管理 





媒体 信息 服务 网 站 








办 公事 务 管理 网 站 








> 业内 部 为 了 进行 广告 及 商品 管理 、 客 户 管 | 广告 及 商品 管理 、 客户 管理 、 


商务 事务 管理 网 站 | : 
i 理 、 合 同 管理 、 营 销 管理 的 网 上 办 公平 台 。 | 营销 管理 








ES 
o = Bn ^ 
1.8.2 ”确定 网 站 的 主题 


网 站 主题 指 网 站 的 题材 。 本 书 案例 网 站 的 主题 是 网 上 售 书 ， 围 绕 着 图 书 来 选择 和 制作 
素材 、 设 计数 据 类 型 等 。 




















确定 网 站 主题 的 原则 


(1) 网 站 定位 要 小 ， 内 容 要 精 。 
(2) 最 好 是 自己 擅长 或 者 喜爱 的 内 容 。 
G) 题材 不 要 太 滥 ， 目 标 不 要 太 高 。 





1.3.3 ”确定 网 站 的 整体 风格 A 


SHRLEPUM SHOP sior ERU GEN QS, 本 书 案例 网 站 的 整 
体 风 格 为 淡雅 、 清 爽 ， 富 有 书香 气息 。 

网 站 的 LOGO 中 使 用 湖绿 (#339999)、 ——T Banner 是 动 
态 展示 网 站 主题 “书籍 是 人 类 进步 的 阶梯 ” 的 GIF 动画 。 

网 站 中 的 标题 、 IT. 反馈 信息 均 采 用 各 自 统一 的 字体 风格 。 

版 面 布局 统一 采用 上 方 固定 、 中 间 根 套 的 浮动 框架 结构 ， 通 过 导航 栏 实现 网 页 之 间 的 
导航 链接 。 XS we 
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确定 网 站 整体 风格 的 原则 
a) 将 网站 LoG6 UTERE DÉR REN. 


Q) 突出 标准 色彩 ， 以 体现 网 站 形象 和 延伸 内 涵 的 色彩 。 

G) 使 用 标准 字体 ， 如 标题 、 标 志 、 茉 单 上 的 特有 文字 ; 若 使 用 非 默认 字体 ， 则 转换 为 图 片 。 

(4) 使 用 统一 的 图 片 处 理 效果 。 把 图 片 定位 于 强化 视觉 效果 、 和 营造 网 页 气氛 、 活 小 版 面 的 功能 ， 
同时 考虑 网 页 下 载 速度 的 因素 ， 图 片 文件 不 宜 过 大 . 





1.3.4 ”确定 网 站 的 内 容 


通常 动态 网 站 中 包含 以 下 内 容 。 

(1) 站 点 结构 图 (Site Map)。 它 是 站 点 结构 、 组 织 方式 的 示意 图 ， 包 含 网 页 的 标题 、 副 
标题 和 主要 栏目 。 
(2) 导航 栏 (Navigation Bar)。 这 是 出 现在 网 站 每 个 页 面 中 的 导航 工具 。 尽 管 使 用 图 片 导 
航 栏 比 单纯 的 文字 效果 更 佳 ， 但 要 有 体现 所 链接 内 容 的 文字 说 明 ;， 注意 使 用 常用 颜色 ; 当 
前 页 面 所 对 应 的 按钮 应 该 相应 地 变 成 灰色 或 突显 ， 导 航 栏 上 要 有 “返回 ” “前 进 ” 按 钮 ， 


指导 用 户 浏览 ， 避 免 迷 航 。 

































































(3) 联系 方式 页 面 (Contact Page)。 可 以 通过 邮件 链接 与 用 户 建立 联系 。 


PHP 动 态 网 页 设计 与 制作 案例 教程 第 版) (了 
- Ma 2 = 
—— 


(4) 反馈 表 (FeedBack Forms)。 用 户 发 表 评论 、 提 出 问题 的 消息 栏 。 

(5) 引人入胜 的 内 容 (Compelling Content)。 这 是 一 些 能 引起 用 户 注意 和 兴趣 的 内 容 。 

(6) 常见 问题 解答 (FAQs)。 列 出 常见 问题 并 与 答案 链接 ， 以 解决 用 户 使 用 时 的 问题 。 

(T) 精美 的 图 片 (Good Graphics)。 虽 然 能 增加 感染 力 ， 但 也 会 影响 下 载 速度 ， 为 此 对 每 
页 的 文字 和 图 像 应 该 做 些 限制 。 

(8) 搜索 工具 (Searching Mechanism)。 提供 站 内 信息 查询 。 这 是 动态 网 站 最 显著 的 特点 ， 
也 是 方便 用 户 最 有 效 的 策略 。 

(9) 新 闻 页 面 (News Page)。 这 是 为 展现 网 站 的 最 新 消息 而 创建 的 单独 页 面 。 为 了 突出 
“最 新 ” 一般 都 在 其 后 添加 亮丽 的 小 图 标 (如 New、 新 ), 同时 在 主页 与 每 个 页 面 加 注 文字 (如 
更 新 时 间 )， 一 段 时 间 后 要 将 其 移 到 适当 的 目录 。 

(10) 相关 站 点 的 链接 (Relevant Links)。 这 样 能 使 用 户 更 有 效 地 找到 相关 信息 ， 同 时 也 
能 通过 这 种 交换 来 推广 站 点 。 为 了 让 用 户 能 清晰 地 了 解 所 链接 的 站 点 ， 应 该 简要 说 明 站 点 
的 功能 以 及 链接 的 原因 。 同 时 还 要 定期 访问 链接 ， 删 除 “ 死 ”的 链接 。 

本 书 案例 中 包含 导航 栏 、 搜 索 工具 、 引 人 入 胜 的 内 容 ( 如 推荐 图 书 、 热 销 图 书 和 特价 图 
书 等 )、 相 关 站 点 的 链接 、 反 馈 表 ( 在 每 本 书 的 详细 资料 页 面 中 设置 用 户 对 该 书 的 反馈 信息 
表 )、 常 见 问题 解答 、 联 系 方式 等 内 容 。 









































ARRAREN” 
(1) 内 容 为 主 ， 注 意 内 容 简 明 通 个 ， 尤其 注重 主页 的 内 容 


(2) 总 体 结构 层 次 分 明 ， 避免 使 用 复杂 的 网 状 结 狗 。 

G) 图 文 和 多 媒体 信息 的 使 用 要 适中 ， 减 少 tt 
(4) 内 容 是 动态 的 》 注意 及 时 更 新 。 00 

(5) 提供 联机 帮助 。 





13.5 规划 界面 


网 页 界面 是 用 户 与 网 站 交互 的 接口 。 编 排 清晰 、 布 局 合理 的 界面 能 提高 用 户 查 询 信息 
的 速度 ， 留 住 用户 。 规 划 界 面 主要 是 编排 好 栏目 和 板块 、 布 局 和 页 面 。 
l. 编辑 栏目 和 板块 


首先 ， 要 列 出 提纲 ， 合 理 收集 与 编排 资料 。 其 次 ， 要 合理 划分 板块 。 
本 书 案例 网 站 的 主页 界面 划分 为 5 个 部 分 。 

(1) 网 站 头 部 : 包括 LOGO, Banner 和 导航 栏 。 

Q) 信息 搜索 板块 : 包括 用 户 表单 搜索 、 图 书 分 类 查询 和 相关 网 站 链接 。 
(3) 主要 内 容 显 示 板 块 : 包括 热 销 图 书 、 推 荐 图 书 和 特价 图 书 等 栏目 
(4) 常见 问题 链接 板块 : 包含 联系 方式 等 栏目 。 

(5) 网 站 版 权 信 息 板块 。 
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编辑 栏目 和 板块 的 原则 


(1) 把 最 有 价值 的 内 容 列 在 栏目 上 方 。 
D 以 访问 者 的 角度 编排 栏目 ， 方 便 浏 览 和 查询 。 





(3) 删除 与 主题 无 关 的 栏目 。 

(4) 板块 比 栏目 大 一 些 ， 既 相对 独立 又 相互 关联 。 

(5) 板块 的 内 容 围绕 网 站 的 主题 展开 。 
2， 布 局 页 面 


布局 页 面 就 是 要 确定 显示 页 面 的 大 小 和 栏目 与 板块 的 位 置 。 
页 面 的 大 小 与 显示 分 辨 素 有 关 。 Sia ed 
浏览 的 妆 罕 性 ， 党 常会 以 800pxx600px 作为 最 低 配 置 。 <<、 
A eA 























本 书 案例 网 站 中 ， 为 了 方便 用 户 浏览 ， 避 免 出 现 水 平 滚动 条 ， 把 页 面 的 宽度 设置 为 
780px， 高 度 不 超过 两 屏 。 网 站 的 主页 选择 型 Ns AURI TEESUR SHIT 
代 主页 的 主要 内 容 板块， 导航 栏 上 注册 、 会 员 管 理 、 顾 客 针 言 及 链接 页 均 选 择 标 题 型 布局 
以 新 窗口 方式 打开 。 " 

A 























S.N "e 
常见 的 页 面 布局 类 型 X 
(0 Tb. p jene. sting. 强调 秩序 、 稳 定 的 优点 ， 但 也 有 果 
板 的 感觉 ， 
Qu in PE n en "a4 信息 量 大 的 优点 ， 但 也 有 页 面 拥挤 、 不 够 
灵活 的 感觉 。 


图 1.10 T 型 布局 E111 口 型 布局 


(3) 标题 布局 。 通 常 为 一 栏 ， 自 上 而 下 依次 为 网 站 名 称 、 广 告 条 、 导 航 栏 、 标 题 、 内 容 、 版 权 信 
息 等 。 这 种 类 型 的 网 页 具有 风格 简练 、 传 达 内 容 直 观 、 功 能 单一 的 特点 ， 主 要 用 于 产品 宣传 、 作 品 
说 明和 发 布 的 网 页 。 





1.3.6 ”规划 站 点 的 目录 结构 和 链接 结构 
站 点 的 目录 结构 是 指 建 网 站 时 创建 的 目录 。 本 书 案例 网 站 的 目录 结构 如 下 所 示 。 


qo 
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e 
wuya 一 一 网 站 根 目录 。 
CSS 一 一 存放 外 置 CSS 文件 。 
images 一 一 存放 图 片 文件 。 
bbs 一 一 顾客 留言 模块 。 
Css 一 一 存放 顾客 留言 模块 的 外 置 CSS 文件 。 
images 一 一 存放 顾客 留言 模块 的 图 片 文件 。 
chat 一 一 聊天 室 模块 。 
CSS 一 一 存放 聊天 室 模 块 的 外 置 CSS 文件 。 
images 一 一 存放 聊天 室 模 块 的 图 片 文件 。 
jsq 一 一 计数 器 模块 。 
images 一 一 存放 计 vitia A 
member 一 一 会 员 管理 模块 。 
CSS 一 存放 会 员 管理 模块 的 外 园 & 文件 。 
images 一 存放 会 员 管理 模 志 的 图 片 文件 。 
register 一 一 登录 与 注册 模块 :一 
CSS 一 一 存放 登录 与 注册 模块 的 外 置 CSS 文件 
images 一 一 存放 登录 : 与 注册 模块 的 图 片 文件 。 
webshop 7 Fs Esp BUR. 
CSS > 上 购书 模块 的 外 置 CSS 文件 。 
images Sox fr Le RUBUS 
bookpic T “> 封面 图 片 文件 
lvl 人 ”一 一 存放 图 书 分 级 图 片 交 件 。 
include ~ 一 “存放 网 上 购书 模 瑞 中 包含 文件 。 
admin 一 一 后 台 管理 员 模块 。 
y WB 一 清 放 后 台 ?管理 员 模块 的 外 置 CSS 文件 。 
ANS y images 一 存放 后 各 管 理 员 模 块 的 图 片 文件 。 
` include 一 一 存放 后 台 管 理 员 模 块 中 包含 文件 。 


规划 网 站 目录 结构 的 原则 


(1) 不 要 将 所 有 文件 都 存放 在 根 目录 下 。 
(2) 应 该 按 栏目 内 容 建立 子 目 录 。 


G) 每 个 目录 下 建立 独立 的 Images B. 
(4) 子 目录 的 层次 不 要 太 深 (一 般 不 大 于 3). 
(5) 不 使 用 中 文 目录 名 ， 目 录 不 要 过 长 。 





链接 结构 是 页 面 之 间 相互 连接 的 拓扑 结构 。 本 书 案例 网 站 的 链接 结构 通过 导航 栏 实现 。 


主页 中 有 3 处 导航 栏 ， 分 别 是 头 部 的 导航 栏 、 特 色 图 书 查 询 导 航 栏 和 底部 


导航 栏 。 在 图 书 分 类 查询 模块 中 会 根据 查询 的 图 书 类 型 链接 到 动态 生成 的 页 面 。 


网 站 链接 的 深度 小 于 3， 凡 与 图 书 和 购物 有 关 的 信息 链接 显示 在 主要 内 容 


@, 


的 常见 问题 





区 域 ， 详 情 


Qe 动态 网 站 设计 概述 
© — | 


信息 显示 在 新 窗口 中 ， 窗 口中 的 “返回 ”按钮 能 关闭 所 在 的 窗口 。 








网 站 链接 结构 的 类 型 


(D 树 状 (一 对 一 ): 首页 一 一 级 页 面 一 二 级 页 面 ……。 这 种 结构 的 效率 低 ， 
D 星 状 (一 对 多 ): 每 个 页 面 间 都 建 链接 。 这 种 结构 容易 产生 “迷航 ”现象 。 
(3) 混合 使 用 : 首页 下 一 级 页 面 下 二 级 页 面 。 


1.3.7 ”编写 网 站 策划 书 








网 站 策划 书 是 对 网 站 规划 的 文档 ， 是 设计 与 制作 网 站 的 基础 和 依据 。 主 要 内 容 包括 前 
期 调查 、 网 站 目标 及 功能 定位 、 网 站 技术 解决 方案 、 网 站 内 容 规 划 、 网 页 设计 、 网 站 维护 、 
网 站 测试 、 网 站 发 布 与 维护 、 网 站 建设 日 程 表 、. 费 用 明细 。 





1.4 “动态 网 站 开发 前 的 准备 


开发 动态 网 站 不 同 于 静态 网 站 。 由 于 要 考虑 存储 网 页 和 资源 的 服务 器 ， 因 此 首先 要 确 
定 服务 器 的 管理 模式 ， 一 般 有 自主 服务 器 、 虚 拟 服务 器 (虚拟 主机 )， 还 要 确定 接 入 Internet 
的 方式 ， 明 确 服务 器 的 性 能 以 及 服务 商 的 服务 。 

144 申请 域名 


在 浏览 器 的 地 址 栏 上 输入 http:/www.cndns.com/， 进入 如 图 1.12 所 示 的 美 橙 互 联网 站 ， 
的 首页 ， 体 验 申请 域名 的 过 程 。 


查询 域名 ze, omascoscisemsacomizes , oara 


VM foa mI , 如 cndns 





图 1.12 申请 域名 (查询 域名 是 否 被 登录 ) 





一 般 地 ， 申 请 域名 包括 以 下 步骤 。 

(1) 确定 域名 注册 代理 商 

D 搜索 域名 ， 查 询 是 否 被 注册 (通过 中 国 互 联网 络 信息 中 心 网 站 )。 
(3) 注册 域名 。 

(4) 注册 用 户 ( 填 写 用 户 名 及 密码 ， 若 已 注册 过 ， 则 不 用 填 申 请 表 )。 
(5) 填写 注册 申请 表 (Web 方式 ， 要 下 载 表 格 )。 

(6) 确定 付款 方式 ， 填 写 发 票 内 容 。 

(7) 订单 确认 (产生 订单 号 )。 

(8) 域名 管理 (基本 信息 修改 、DNS 的 修改 、URL 转发 功能 )。 























互联 网 服务 提供 商 (ISP) 
互联 网 服务 提供 商 (Internet Service Provider, ISP) 是 向 广大 用 户 综合 提供 互联 网 接 入 业务 、 信息 
业务 和 增值 业务 的 电信 运营 商 。 ISP 是 经 国 家 主管 部 门 批 淮 的 正式 运营 企业 ， 享受 国家 法 律 保护 ,中 
国电 信 、 中 国 移动 、 中 国联 通 为 中 国 的 三 Aia. 其 他 的 有 中 国教 育 和 科研 计算 机 网 、 中 国 
科技 网 、 长 城 宽带 等 。 


py wo 


互联 网 数据 中 心 Internet Data Center, IDC) tr 41m 已 有 的 互联 网 通信 线路 、 带 宽 资 
源 ， 建立 标准 化 的 电 入 专业 级 机 房 环境 ， Ae 共和 可 和 租用 及 相关 增值 等 方面 的 
全 方位 服务 T í 


互联 网 内 容 提 供 商 (ICP) 


互联 网 内 容 提供 商 (Internet Content Provider，ICP) 是 向 广大 用 户 综合 提供 互联 网 信息 业务 和 增值 
业务 的 电信 运营 商 。 ICP 同样 是 经 国家 主管 部 门 批准 的 正式 运营 企业 ， 享 受 国家 法 律 保护 。 国内 知名 
的 ICP 有 新 浪 、 搜 狐 、163、21CN 等 。 





1.4. $&A Internet 


.主机 方式 




















户 为 自己 的 机 器 申请 IP 地 址 ， 直 接 接 入 Intermet， 用 户 机 是 一 个 独立 的 点 ， 但 费 
高 ， 申 请 使 用 公用 通信 网 络 可 通过 DDN 专线 和 X.25 分 组 交换 网 。 
需要 的 设备 包括 计算 机 (PC)、 网 卡 、 专 线 Modem、 通 信 软 件 ， 如 图 1.13 所 示 。 
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图 1.13 主机 方式 接 入 Internet 示意 
2. 局 域 网 方式 


局 域 网 方式 是 指 连接 成 一 个 文件 服务 器 型 的 局 域 网 ， 再 把 服务 器 以 主机 方式 接 入 
Internet。 局 域 网 上 的 用 户 共享 该 服务 器 TP 地 址 (内 部 IP 地 址 )， 不 能 直接 访问 Internet, 15 
不 能 被 Internet 用 户 访问 ， 访 问 请 求 由 服务 器 转发 (代理 服务 器 )， 如 图 1.14 所 示 。 


局 域 网 (内 部 网) 


图 1.14 局 域 网 接 入 Internet 示意 





















”网 线 / 串 连 线 


3. Internet 子 网 方式 

Internet 子 网 由 多 台 计 算 机 连 成 一 个 局 域 网 申请 到 足够 多 的 IP 地 址 ， 通 过 路 由 器 把 
现 有 的 局 域 网 连接 到 Internet. 上 ， 不 受 限 制 地 访问 。 

需要 的 设备 有 路 由 器 、 交 换 机 、 服 务 器 、PC 工作 站 和 上 网 专线 (DDN 专线 、 光 缆 )， 如 
图 1.15 所 示 。 





1.15 Internet FRIZA Internet 示意 


4. ADSL/VDSL 方式 

非 对 称 数 字 用 户 环 路 (ADSL) 是 信息 高 速 公路 上 的 快车 ， 具 有 以 下 特点 : 

(D 速率 高 :下载 速率 大 于 8MbiVs， 上 传 速率 大 于 640Kbit/s。 

(2) 频带 宽 : 256 倍 以 上 。 

(3) 性 能 优 。 

(4) 应 用 广 : 家 庭 办 公 、 远 程 办 公 、 高 速 上 网 、 远 程 教育 、 远 程 医疗 、VOD 点 播 。 

VDSL tk ADSL 还 要 快 。 短 距离 内 的 最 大 下 传 速率 可 达 55Mbit/s， 上 传 速率 可 达 
2.3Mbit/s。 

5. Cable-Modem 方式 

Cable-Modem( 线 缆 调制 解 调 器 ) 是 近年 来 开始 试用 的 一 种 超 高 速 Modem， 它 利用 现成 
的 有 线 电视 (CATV) 网 进行 数据 传输 。 可 分 为 两 种 : 对称 速率 型 和 非 对 称 速率 型 。 前 者 的 
Data Upload( 数 据 上 传 ) 速 率 和 Data Download( 数 据 下 载 ) 速 率 相同 ,都 在 500Kbit/s~2Mbit/s; 
后 者 的 数据 上 传 速率 在 500Kbit/s 一 10Mbit/ls， 数 据 下 载 速 率 为 2 一 40Mbit/s。 
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6. PSTN 方式 








PSTN(Published Switched Telephone Network， 公 用 电话 交换 网 ) 技 术 是 利用 PSTN 通过 
Modem 拨号 实现 用 户 接 入 的 方式 。 这 种 接 入 方式 的 最 高 传输 速率 为 56Kbit/s， 远 远 不 能 够 
满足 宽带 多 媒体 信息 的 传输 需求 :但 由 于 电话 网 非常 普及 ， 用 户 终端 设备 Modem 很 便宜 ， 
而 且 不 用 申请 就 可 开户 , 只 要 家 里 有 计算 机 , 把 电话 线 接 入 Modem 就 可 以 直接 上 网 。 可 见 
PSTN 拨号 接 入 方式 比较 经 济 ， 但 随 着 宽带 的 发 展 和 普及 ， 这 种 接 入 方式 将 被 淘汰 。 


143 ”选择 软 硬 件 平台 
l. 网络 的 逻辑 结构 
基于 Web 的 系统 一 般 采 用 3 层 结构 ， 如 图 1.16 所 示 。 


"rrr A 
! Web 服 务 器 ! 中 间 层 
1 
1 1 
1 M 


nm | 第 2 层 
图 1.16 B/S 的 3 层 结构 


Web 服务 器 : 直接 面向 用 户 ， 主 要 运行 ,HTTP 服务 ， 提 供 浏览 功能 ， 可 运行 应 用 程序 
的 数目 取决 于 网 站 的 大 小 和 实际 的 负载 量 ;- 对 计算 机 处 理性 能 要 求 较 高 。 

中 间 层 : 事务 处 理 罗 辑 ， 也 称 为 应 用 服务 器 。 它 是 最 重要 的 环节 ， 是 对 不 同 的 数据 库 
操作 的 接口 。 

数据 库 服务 器 : 也 称 为 后 从 服务 器 ， 网 站 动态 数据 内 容 存储 的 地 方 ， 用 到 的 数据 库 服 
务 器 的 数目 取决 于 网 站 的 规模 和 应 用 的 大 小 。 

2. Internet 接 入 设备 


Internet 接 入 设备 主要 包括 以 下 方面 。 

(1) Web 服务 器 主要 考虑 多 处 理 器 的 主板 、 足 够 的 缓存 、 足 够 的 内 存 等 技术 要 求 。 
(2) 硬盘 要 考虑 速度 快 、 可 靠 性 高 等 技术 要 求 。 

G) 其 他 支持 的 设备 包括 不 间断 电源 设备 (UPS) 和 网 卡 。 


14.4. 选择 网 站 建设 服务 商 
随 着 网 络 资源 服务 市 场 的 成 熟 ， 主 要 有 三 种 基本 的 服务 器 构建 方式 ;服务 器 托管 、 


机 租用 及 虚拟 主机 。 为 了 满足 个 人 对 网 站 建设 的 需求 ， ER ET EE 
间 。 随 着 云 技术 的 发 展 ， 还 出 现 了 云 服务 器 和 云 虚 拟 主机 。 


.服务 器 托管 


在 浏览 器 的 地 址 栏 上 输入 http://www.todayide.com/， 进 入 时 代 互 联网 的 首页 ， 选 择 导 
航 栏 上 的 “服务 器 托管 ”链接 ， 如 图 1.17 所 示 ， 可 见 服务 器 托管 的 报价 。 
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以 下 价格 不 合 发 票 税 


珠海 电信 数据 中 心 ker (s) 
A 了 主机 只 需 520 元 月 ew 
F 珠海 电信 机 房 出 口 沉 亮 40G, 通过 10G 光 年 直接 与 ChinaNet 广 东 省 骨干 节点 互 连 ， 并 以 见 余 线路 


结构 保证 高 速 可 千 * 托管 机 房 设施 一 流 ， 两 路 市 电 、 自 备 发 电机 及 UPS 儿 路 电源 保证 。 数据 中 心 
的 重要 网 络 设备 采用 双 点 备份 ， 苗 免 单 点 雪 障 ， 增 湿 了 同 络 的 可 靠 性 。 数据 中 心 设 有 DNS 服 务 


器 ,可以 为 用 户 提供 正 向 、 反 向 解析 域名 等 服务 。 
THER] 





E5RM 
TUJE 管 价格 pores BUHUSI BIHeHCRE HE. 
520,5 5200 550 5500 年 1050/8 10500% 8288 月 82880 年 


semx DI zmmx] 








图 1.17 时 代 互 联网 的 “服务 器 托管 ”页 面 (部 分 ) 


托管 服务 器 是 放置 在 与 Internet 实时 相连 的 网 络 环境 的 ISP 机 房 的 一 台 服 务 器 ， 或 向 其 
租用 一 台 服 务 器 ， 客 户 可 以 通过 远程 控制 将 服务 器 配置 成 WWW、FTP、…， 委 托 给 ISP 保 
管 ， 将 设备 放 到 IDC 的 中 心机 房 或 数据 中 心 ， 通 过 低速 线路 远程 管理 和 维护 ， 其 特点 如 下 。 

(1) 享受 IDC 的 优越 的 硬件 设施 和 资源 。 

(2) 节约 管理 和 维护 人 员 等 开支 ， 并 能 保障 网 络 安全 防护 。 

G) 具有 独 享 性 ， 既 不 会 因 主 机 负载 过 重 而 导致 服务 器 性 能 下 降 或 瘫痪 ， 也 不 会 因 共 
部 资源 而 影响 响应 速度 和 连接 速度 。 





(4) 适合 于 对 安全 性 和 稳定 性 要 求 比 较 高 的 企业 和 团体 ,如 OA 系统 和 内 部 数据 管理 
2. 租用 服务 器 


在 时 代 互 联网 的 首页 ， 选 择 导航 栏 上 的 “服务 器 租用 ”链接 ， 如 图 1.18 所 示 ， 可 见 服 
务 器 租用 的 报价 。 


服务 器 租用 8 机房 和 续 租 用 服务 器 一 年 以 上 . 租用 服务 器 产权 归 容 户 所 有 ) E> 
SETTER E EE 7 


ee guy A E. 


CPU:Xeon E5645*2+—# 。 。 CPU:Xeon E5-2620~2 十 二 核 CPU:Xeon E3-1230v2 pülk CPU: 6.2900 pc 


内 存 :8G RECC DDR3 1333*4 内存 :16G BRECC DDR3 1333 "2 内 存 :8G DDR3 1333 内 存 :8GB DDR3-1333 
硬盘 :1000GB~2on Raid 硬盘 ;1000GB*2on Raid — 硬盘 :SSD120G+500GB SATA III 硬盘 ;64GB SSD 
网 卡 : 双 干净 高 性 能 P 卡 同 卡 ; 双 千 北 高 性 能 问 卡 同 卡 ; 双 千 北 高 性 能 隔 卡 PERDERA 


KÄE Br 天 -年 送 一 年 买 一 年 送 一 个 月 
现价 34820 元 /年 现价 358007t/ 年 现价 : 17400 元 /年 现价 :69997t/ 年 
半年 价 :23280 元 站 年 价 :21480 元 丰年 价 : 124807 丰年 价 :4500 元 


HERE WIRE vme [E ows) ewm 国 立即 购买 
图 1.18 ”时代 互联 网 的 “服务 器 租用 ”页 面 (部 分 ) 























租用 服务 器 的 用 户 无 须 自己 购买 主机 ， 只 需 根据 自己 业务 的 需要 ， 提 出 对 硬件 配置 的 
要 求 ， 主 机 服务 器 由 IDC 配置 用户 采取 租用 的 方式 ， 安 装 相应 的 系统 软件 及 应 用 软件 以 
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实现 用 户 独 享 专 用 高 性 能 服务 器 ， 其 特点 如 下 。 
1) 便捷 和 低 价 。 相 对 于 购买 独 享 的 服务 器 ， 租 用 一 台 服 务 器 上 的 空间 就 能 满足 要 求 ， 
能 为 用 户 节省 很 多 费用 。 
(2) 部 署 简单 、 方 便 。IDC 能 够 根据 用 户 需求 提供 最 适合 的 系统 。 
(3) 即 买 即 用 。 用 户 根据 需求 购买 或 不 购买 ， 从 而 避免 产生 硬件 垃圾 。 
(4) 适合 于 对 访问 量 不 大 的 网 站 。 如 企业 网 站 初期 。 
3. 虚拟 主机 
在 浏览 器 的 地 址 栏 上 输入 http:Wwww.westcn， 打 开 西部 数据 网 站 的 首页 ， 选 择 导航 栏 
上 的 “虚拟 主机 ”链接 ， 进 入 如 图 1.19 所 示 的 页 面 。 
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图 1.19 万 网 提供 的 主机 服务 器 价格 页 面 (部 分 ) 


虚拟 主机 指 租用 IDC 服务 器 硬盘 空间 ;使 用 特殊 的 软 硬 件 技术 ， 把 一 台 计算 机 主机 分 
成 许多 台 虚 拟 的 主机 , 每 台 虚 拟 主机 都 有 独立 的 域名 或 IP 地 址 (共享 IP) 并 有 完整 的 Internet 
服务 器 。 按 租用 的 空间 大 小 和 网 络 带宽 资源 收费 。 其 优点 是 省 去 了 全 部 硬件 投资 ， 缺 点 是 
不 能 支持 高 访问 量 ， 适 合 于 搭建 小 型 网 站 。 

虚拟 专用 服务 器 (Virtual Private Server, VPS) 是 利用 虚拟 服务 器 软件 (如 微软 的 Virtual 
Server, VMware 的 ESX server, SWsoft 的 Virtuozzo) 在 一 台 物 理 服务 器 上 创建 多 个 相互 隔 
离 的 小 服务 器 。 这 些小 服务 器 本 身 就 有 自己 的 操作 系统 ， 它 的 运行 和 管理 与 独立 服务 器 完 
全 相同 。 虚 拟 专 用 服务 器 确保 所 有 资源 为 用 户 独 享 ， 给 用 户 最 高 的 服务 品质 保证 ， 让 用 户 
以 虚拟 主机 的 价格 享受 到 独立 主机 的 服务 品质 。 

4. ERAS 

图 1.19 中 还 看 到 了 “ 云 服务 器 ”链接 ， 单 击 这 个 链接 ， 观 察 对 云 服务 器 的 报价 信息 。 
在 浏览 器 的 地 址 栏 上 输入 http://www.now.cn/vhost/index_new.php， 进 入 如 图 1.20 所 示 
的 时 代 全 能 云 虚 拟 主机 的 页 面 。 图 1.20 列 出 了 云 虚拟 主机 的 配置 信息 ， 右 侧 也 有 传统 的 虚 
拟 主机 的 入 口 ， 从 中 可 以 比较 云 服务 器 、 云 虚拟 主机 和 虚拟 主机 的 区 别 。 
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时 代 全 能 云 虚拟 主机 





图 1.20 ”时 代 互 联网 提供 的 云 虚拟 主机 页 面 (部 分 ) “ 


云 服务 器 是 一 种 简单 高 效 、 安 全 可 靠 、 处 理 能 力 可 弹性 伸缩 的 计算 服务 。 其 管理 方式 
比 物 理 服务 器 更 简单 高 效 。 用 户 不 需要 提前 购买 硬件 中 即 可 迅速 创建 或 释放 任意 多 台 云 服 
务 器 。 云 服务 器 能 实现 快速 构建 更 稳定 、 安 全 的 应 用 7 并 且 能 降低 开发 及 运行 与 维护 的 难 
度 和 整体 IT 成 本 ， 使 用 户 能 够 更 专注 于 核心 业务 的 创新 。 

云 虚拟 主机 是 对 云 服务 器 的 进一步 划分 。 通 过 虚拟 主机 管理 软件 ， 把 云 服务 器 分 割 成 
100M、200M 等 型 号 的 小 型 空间 。: 云 虚拟 主机 是 中 小 型 企业 建站 的 最 佳 选择 。 


NL 


5. 个 人 空间 E : 

在 浏览 器 的 地 址 栏 上 输入 http://wwwfree789.coni/webspace/php， 进 入 如 图 1.21 所 示 的 
全 球 免费 中 心 网 站 的 -PHP 免费 空间 页 面 。 其 中 列 出 了 最 新 的 PHP 免费 空间 信息 ， 从 中 可 
以 进行 比较 ， 选 择 所 需要 的 服务 商 以 建立 个 大 空间 。 





EEE ES NOE WEA OM TM OE MME 
ree789 免 费 空间 网 主页 | 博客 | 论坛 PB | 存储 | 图 片 | 相册 | 自助 | MS | ASP | PHP | or | oer | aep | Paprcol | 全 能 | 其 它 


GB. o > 免费 phi EE 
当前 位 置 ， free789 免 费 中 心 》free789 免 费 空间 网 》 免 费 php 空 间 ern 


w 2005/086/165 586088 186788, (819018. FEES FAISE 8181078418 15 8528 
aix 


3 ptp conl 
38 ABS 


&ReEGH k BRHIHIEDUCRBHERTIH, THE, mier oim 
供 110w 免 费 vbp 主 页 空间 申请 《 附 芝 孝 
ntoto Sa amA AR 
nfc 提 供 16 免 费 bhp 空 间 申请 - 教 笃 c 

(ABI RD S 365 -tosting 无 三 告 158 免 费 php 空 间 申 请 Ip 

(Reis 2k 1gb. se (0009. us) BARK ICE Bebe mia] 支持 .bra 

(BH k yezcka 提 供 1200M 永 久 免 费 pkp 空 间 Xr Mc oo IAE 

二 shptezi 空 间 ?二 Reafebtost 无 广告 30 各 费 PHP-C0I 宁 间 支持 Ftp sum 

RREA ik Freetzi 提 供 500y 可 丹 米 免费 php 宁 间 i 


1.21 free789 免费 中 心 网 站 的 PHP 免费 空间 页 面 








个 人 空间 以 个 体形 式 制作 和 发 布 网 站 ， 并 提供 网 络 服务 。 网 上 提供 的 个 人 主页 空间 分 
免费 和 收费 两 种 ， 其 特点 如 下 。 
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(1) 空间 一 般 都 比较 小 ， 但 费用 低 。 
Q) 支持 服务 器 端 脚本 、 电 子 商 务 和 其 他 工具 有 限 。 
(3) 适用 于 发 布 个 人 信息 。 


a 
本 章 总 结 


本 章 从 体验 入 手 ， 介 绍 了 动态 网 站 的 特点 、 运 行 机 制 和 开发 流程 ， 并 通过 对 网 上 书店 
案例 的 规划 ， 解 析 了 动态 网 站 规划 的 内 容 、 过 程 和 方法 ， 为 进一步 学 习 黄 定 了 基础 。 


CO sans 


(1) 辨析 以 下 概念 ; 

@ 网 站 、 网 页 和 主页 。 

Q 客户 端 、 浏 览 器 和 服务 器 。 

图 HTML, JavaScript 和 PHP。 \ 

@ 数据 文件 和 数据 库 。 NNI 

€) 域名 、IP 地 址 和 URL. VS 

(2) 画图 描述 : 

Q) 客户 端 、 WA BR tS HUE RR 

Q 服务 器 解析 程序 时 的 数据 流 。 

6) FUEN RASKERE ERRIZ. 


SATT 


项 目 1-1 cO: 
项 目 目标 : 
(1) 浏览 电子 商务 网 站 ， 如 当当 网 、 上 海 书城 等 网 站 ， 了 解 网 上 书店 的 内 容 和 功能 。 
D 浏览 时 代 互联 网 站 、 网 人 科技 、 第 一 主机 屋 等 网 站 ， 了 解 建站 的 模式 和 费用 。 
G) 写 一 份 “ 网 上 书店 ”的 网 站 建设 规划 书 。 
项 目 1-2 梳理 网 站 建设 中 对 服务 器 的 认识 
项 目 目标 : 
(1) 通过 维基 百科 、 百 度 文库 等 网 上 资源 调研 几 种 典型 的 服务 器 类 型 。 
Q) 区 分 开发 网 站 中 的 服务 器 与 IDC 提供 的 服务 器 。 
G) 从 不 同 的 角度 列表 描述 这 些 服务 器 的 优 缺 点 和 适用 范围。 
项 目 1-3 调研 网 上 免费 PHP È id 
项 目 目标 : 
(1) 使 用 百度 、Google 等 搜索 工具 搜索 有 关 免 费 PHP 空间 的 信息 。 
(2) 写 一 份 关于 “网 上 免费 空间 ”的 调研 报告 。 



























































ES 
e 相关 资源 


(1) 中 国 万 网 : http://wanwang.aliyun.com。 
(2) 易 网 中 国 : http://www.idcca.com。 

(3) 中 华 数据 : http://www.chinese.bj.cn。 
(4) 网 人 科技 : http://www.wangren.com。 
(5) 第 一 主机 : http:/wwwl.com.cn。 

(6) 时 代 互 联 : http://www.todayidc.com。 
(7) 免费 空间 : http://www. free.v.do。 
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动态 网 站 编程 环境 


通过 本 章 的 学 习 ， 能 够 使 读者 : 

(1) 理解 动态 网 页 编程 环境 的 构成 要 素 。 

(2) 掌握 动态 网 页 编程 环境 的 安装 方法 。 

(3) 了 解 与 动态 网 页 编程 环境 相关 的 配置 文件 。 


FIRR 


本 章 为 读者 准备 了 以 下 学 习 资源 : 

(1) 示范 案例 : 展示 “动态 网 站 编程 环境 的 搭建 ”的 过 程 和 方法 ， 对 应 本 章 的 2.4-2.5 
节 。 案例 所 需 的 软件 存放 在 “教学 资源 /ch2/software” 中, 也 可 从 对 应 节 的 下 载 资源 中 获得 。 

(2) 技术 要 点 : 描述 “动态 网 站 编程 环境 的 构成 要 素 ” 以 及 “PHP 动态 网 站 集成 开发 
工具 ”， 对 应 本 章 的 2.1 节 和 2.6 节 。 

(3) 实验 项 目 : 要 求 参考 示范 案例 ， 自 己 配置 学 习 PHP 动态 网 站 开发 的 环境 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 : 

(1) 解读 动态 网 站 编程 环境 的 构成 要 素 , 这 是 配置 PHP 开发 环境 和 开发 PHP 动态 网 站 
的 基础 。 
(2) 模仿 练习 : 选择 一 个 PHP 集成 开发 工具 ， 如 AppServ， 按 照 实现 步骤 重 现 案例 。 

(3) 扩展 练习 : 通过 网 络 搜索 ， 了 解 PHP 集成 开发 工具 ， 学 习 安 装 和 配置 PHP 集成 开 
发 环境 。 

学 习 过 程 中 ， 提 倡 结对 或 3 人 组 成 学 习 小 组 ， 采 取 分 工 合作 ， 交 流 学 习 的 心得 、 经 验 
和 体会 ， 也 能 培养 协作 精神 ， 会 得 到 更 多 的 收获 。 
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本 章 案例 是 搭建 动态 网 站 的 编程 环境 ， 详 细 地 介绍 在 Windows 操作 系统 上 安装 、 配 置 
和 测试 动态 网 页 编程 环境 的 方法 和 过 程 。 

动态 网 页 编程 环境 包括 服务 器 端 程序 Apache、 编 程 语 言 PHP、 数 据 库 MySQL 及 图 形 
化 数据 库 MySQL 的 管理 系统 phpMyadmin。 因 此 ， 需 要 对 这 4 个 软件 分 别 进行 安装 ， 也 可 
以 使 用 组 合 了 这 4 个 软件 的 软件 包 ， 如 AppServ。 
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2.1 动态 网 页 编程 环境 的 构成 要 素 


要 搭建 动态 网 页 的 编程 环境 ， 首 先 要 认识 编程 环境 的 构成 要 素 。 构 成 动态 网 页 的 编程 
环境 的 要 素 包括 操作 系统 、 服 务 器 端 程序 、 编 程 语言 和 数据 库 。 
24.1. 操作 系统 了 

1. UNIX/Linux VAL 


UNIX 是 由 贝尔 实验 室 研发 的 多 用 户 、 多 任务 、 支持 多 种 处 理 机 架构 的 操作 系统 ， Jt 
有 可 靠 性 强 、 伸 展 性 突出 、 安 全 性 高 、 技 术 成 熟 等 特点 -“ 
Linux 是 免费 的 、 与 UNIX 完全 相 容 的 操作 系统 (作业 系统 ), 是 当前 主流 操作 系统 之 一 。 


2. Windows . 


Windows J£ Microsoft 公司 推出 的 多 任务 图 形 化 操作 系统 ， 具 有 易 用 、 速 度 快 、 集 娱乐 
和 网 络 等 功能 于 一 体 的 特点 ， 是 当前 主流 操作 系统 之 一 。 
目前 的 操作 系统 主要 有 32 位 和 64 位 ， 在 其 上 运行 的 软件 也 有 这 样 的 划分 。 


2.1.2 ”服务 器 端 程序 
l. Apache 


Apache 支持 多 种 Web 编程 语言 ， 具 有 开源 性 、 安 全 性 好 、 扩 展 性 高 、 多 平台 上 可 用 
特点 。Apache 是 Linux/UNIX 内 定 的 服务 器 程序 ， 也 有 Windows 版 本 。 


2. IIS 


IIS 是 Windows 的 一 个 组 件 ， 需 要 Windows NT Server 支持 。 它 支持 与 语言 无 关 的 脚本 
编写 和 组 件 并 直接 支持 ASP。 


24.3 ”程序 语言 














E 




















1l. PHP 
PHP(Hypertext Preprocessor) — ft HTML 内 赃 式 的 、 在 服务 器 端 执行 的 脚本 语言 ， 其 
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语法 结构 与 C 语言 的 风格 非常 相似 。PHP 具有 平台 无 关 性 、 效 率 高 、 功 能 全 面 、 支 持 多 种 

数据 库 面向 对 象 编程 、 可 伸缩 性 、 可 扩展 性 、 易 学 易 用 、 开 源 软 件 等 特点 。 

2. ASP/ ASP.NET 

ASP(Active Server Pages) 是 Microsoft 公司 开发 的 一 种 后 台 脚 本 语言 ， 其 语法 和 Visual 
Basic 类 似 ， 可 以 像 SSI(Server Side Include) 那 样 把 后 台 脚 本 代码 内 蔡 到 HTML 页 面 中 ， 简 


单 易 用 ， 但 平台 相关 性 和 安全 性 使 其 具有 一 定 的 局 限 性 。ASPNET 借鉴 了 Java 技术 的 优 
点 ， 使 用 C# 语 言 作为 ASPNET 的 推荐 语言 ， 同 时 改进 了 以 前 ASP 的 安全 性 差 等 缺点 。 


3. JSP 



























































JSP(Java Server Pages) 是 Sun 公司 的 J2EE(Java 2 platform Enterprise Edition) 应 用 体系 中 
的 一 部 分 。 其 主要 特点 是 平台 无 关 性 、 效 率 高 、 安 全 性 好 。 


2.1.4 ”数据库 
. MySQL 


MySQL 是 完全 网 络 化 的 跨 平 台 关 系数 据 库 系统 ; 具有 CIS HR ASMURVAY i SER PE 
理 系统 的 特点 。 可 利用 许多 语言 编写 访问 MySQL. 数据 库 的 程序 。 其 主要 优点 有 支持 千 万 
条 记录 的 数据 仓库 、 适 应 所 有 平台 、 开 源 使 用 简单 、 安 装 方便 。 


2. SQL Server 


SQL Server 是 Microsoft 公司 在 Windows 平台 上 开发 的 关系 数据 库 系 统 。 具 有 易于 使 
有、 兼容 性 好 、 适 应 性 较 强 的 特点 ， 也 是 C/S 体系 结构 ， 并 结合 了 电子 商务 的 特点 ， 如 数 
据 仓库 、 在 线 商务 、OLAP 等 。 N 


3. Oracle. 


Oracle 是 Oracle 公司 开发 的 关系 数据 库 系统 。 采 用 C/S WRA, HUE TUE, 3E 
容 性 好 、 移 植 性 好 的 特点 ， 并 提供 完整 的 电子 商务 服务 。 


4. PostgreSQL 


与 MySQL 一 样 ，PostgreSQL 也 是 一 个 开源 数据 库 管 理 系统 ， 提 供 了 外 键 、 子 选项 、 
事务 、 触 发 器 和 视图 等 功能 。 


2.1.5 基于 PHP 常见 动态 网 站 开发 环境 
根据 动态 网 页 编程 环境 的 构成 要 素 ， 基 十 PHP 的 动态 网 站 开发 环境 有 以 下 组 合 。 
1. 组 合 1 






























































TE Linux/UNIX 上 安装 PHP 和 MySQL, 即 所 谓 的 LAMP: Linux+Apache+PHP+MySQL。 
2. 组 合 2 


在 Windows 上 安装 Apache. PHP 和 MySQL， 并 配置 为 协调 工作 的 编程 环境 ， 即 
Windows--Apache- PHP-MySQL. 
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3. 组 合 3 





在 包含 IIS 组 件 的 Windows 上 安装 PHP 和 MySQL 并 配置 为 协调 工作 的 编程 环境 ， 即 
Windows+IIS+PHP+MySQL。 

根据 系统 的 规模 ， 也 可 以 选择 其 他 数据 库 系统 。 

本 书 建 议 的 动态 网 页 编程 环境 的 主要 参数 如 表 2.1 所 示 。 


表 2.1 配置 动态 网 页 编程 环境 的 主要 参数 




































计算 机 环境 64 位 32 位 其 他 
操作 系统 Windows 10 Windows 7 
服务 器 端 程序 Apache 2.4.18 x64 vcll Apache 2.4.18 x32 vcll VCII 
程序 语言 php-5.6.17-Win32-vcll-x64.zip php-5.6.17-Win32-vcl1-x86.zip VCII 
数据 库 mysql-5.6.28-winx64.zip mysgl-5.6.28-winx32.zip 
数据 库 管理 系统 | phpMyAdmin-4.5.4.1-all-languages.zip | phpMyAdmin-4.5.3.1-all-languages.zip 
集成 包 AppServ8.0 VC14 
网 页 开发 环境 Dreamweaver 或 记事 木 
浏览 器 IE 或 Firefox 或 其 他 的 浏览 器 





2.2 安装 和 配置 Apache 


P 


ERLEARI FRE PRAG ZR SES 
2.2.1 E Apache 前 的 准备 
l. 下载 Apache 
(1) 在 浏览 器 的 地 址 栏 上 输入 http://httpd.apache.org/， 进 入 如 图 2.1 所 示 的 页 面 。 


x 
HTTP SERVER PROJECT 


The Number One HTTP Server On The Internet 


The Apache HTTP Server Project is an efior to develop and mantan an open-source HTTP server tor modem operating systems including UNIX and 
"Windows NT The goal of thes project a to provide a secure. emcent and extenstie server at provides HTTP services in Sync wih me current HTTP. 
andards 


Apache httpd was launched in 1995, has been the most popular web internet since Apri 1996, and celebrates its 20 birthday as a project his 
Fetnany. 


The Apache HTTP Server (ipi) is a project of The Agache So 


Apache httpd 2.4.18 Released ERED 


The Apache Sonware Foundation and the Apache HTTP Server Project are pleased to announce the release of version 2.4.18 of Ine Apache HTTP Server 
CApacne") This version of Apache is our latest GA release of he new generaton 2 4X branch of Apache HTTPD and represents ten years of innovation 





2.1 Apache 官方 网 站 主页 
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(2) 找到 Apache httpd 2.4.18 Released 
的 页 面 。 





选择 “Download” 链 接 ， 进 入 图 2.2 所 示 











HTTP SERVER PROJECT 


p" Downioading Me Apache HTTP Server 


-aas (Usa me aa been to downloa me Apache HTTP Server Pom ene ot our mers You must vety e ingray of Me eowrloaged tes utag sonatine 
m romroeoea wom vw Tan Quir uoon eecton 
aa 
DSim Reoons Ony cumem ‘ecommenged recascs are svaapie on pe mon gpeueon stt eng Es maro OOC MICAS rcvong DC 1:289. 20 iamacs of releases, 
ardeat Pom De iin panad M 
Apache ho Vr Micro wnooes 6 sapie rom 
tate we ea Latest verson 
LU emen i55 nia) 
Lagay Reease -zz Dranen 
~ LLM (eed 2015.07.10) 
Myou as dosnioaóng Pe Vini? datibuton uiae roa Pese ereot notis 


The aunenty selecte murar s Nipmimors ene enapache! Ifyou encounter a protem wën mco, ease «eec anoter mtor at mima 
faing Iere are baci minos (af e end o he eror a) Fat uk be aa 
~ Bug Reports is comi Tc] 


Yo may aso consut tne comlele IsI GUTTA 





Apache HTTP Server 2.4.18 (httpd): 2.4.18 is the latest avallable versjón, 
The Apache HTTP Server Project s pleased to announce me release of version 24-11 ot the Agache HTTP Server Apache" and ttp?) This version of 
Apache is our iatest GA release of the new generabon 2 4 x branch of Apache HITPO and 'epresents tieen years of innovation by Ine proec, and is 
recommended over as previous releases! 
For Geta see ne Oficial Announcement and pe CHANGES. 2 Fari CHÁNGES. 74 15 ets 
* Source lpd2.4. 19ac bz2 [PGP ] MOS TL SHAT I 
* Source hnd2.4 10 targe [ PGP | MDS [Stk 
+ Contributo * Banes 


* Sponsory 


一 一 网 * Securty and oficiat patches 





图 2.2 选择 下 载 Apache httpd 2.4.18 方式 的 链接 





8j Apache HTTP Server 2.4.1 8(httpd):2.4.18 is the lastest available version 区 域 ， 选 
7f “Files for Microsoft Windows” 链 接 ， 进 入 图 2.3 所 示 的 页 面 。 


= Apache HTTP Server Version 2.4 
Anach > HTTP Server» Documantatan > Version 24» Parm Specie Notes 





Using Apache HTTP Server on Microsoft Windows 

ET 
This document expains how o install, confgure and run Apache 2 4 under Mcroso Windows. It you nave queshons aer revewng me 
documentation (and any event and error logs) you nou consum ne peer-suppored user mating st 


This document assumes tnt you are Istaing a binary distrouton of Apache. If you want to compie Apache yourseit (possibly to heip win 
development or tracking down bugs) see Compiing Apache or Microsoft Windows: 


& 
5 EE Testing e lostataton 


© Contouring Access to 
The primary Windows platform for running Apache 2.4 is Windows 2000 or iater. Aways obtain and insta the current service pack to avoid Neteo Resources 
operating system bugs. * Windas Tuning 

* Commants 

Apache HTTP Server versions iater man 2 2 wii not run on any operating system earter han Windows 2000. 


Downloading Apache for Windows 


The Apache HTTP Server Project tei does not provide binary reeases of sofware. oniy source code. Indidual comiters may provide binary 
packages as a convenience, but it is not a release deiveranie 


Myou cannot compie me Apache HTTP Server yourself, you can bn a binary package from numerous binary dirbiions avatable on the 
iniemet 


Popular options tor deploying Apache npa. and, optonaly PHP and MySQL. on Mirosof Windows. moude: 














图 2.3 选择 下 载 Apache httpd 2.4.18 的 链接 网 站 
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(4) 找到 Downloading Apache for Windows 区 域 ， 选 择 “ApacheHaus” 或 “Apache 
Lounge” 链 接 ， 进 入 图 2.4 所 示 的 页 面 。 





£N 注 ApacheHaus 和 Apache Lounge 都 是 第 三 方 下 载 平台 ， 在 其 网 站 可 下 载 独立 的 Apache 压缩 包 。 
另外 3 个 是 集成 开发 环境 。 


The 


Apache 


Haus 
Apache" binaries for Windows® 


search Apache Haus 
Home >> Downloads 


Apache Haus Downloads 


E Mee ter Apache binaries are buit with the original source released by the Apache Software Foundalian (unless noted) and have been compiled with 
à Visual Studio 2008 (VC9) or Visual Studio 2012 (VC1 1) to obtain higher performance sad bett stabit than the binaries buit by the Apache. 
Sotware Foundaton. 


Binaries are built using the latest versions of the Apache Portable Runtime, OpenSSL and Zlib compression library. OpenSSL and Zlib are 
built using the optional assembly routines for added performance in the SSL and deflate modules. 


After downloading and before you install, you should máke sure hat te fle is intact and has not been tampered with. Use the SHA 
Checksums to verity the integrity. 





OpenSSL Updates 2.4 CO VCO Redisirbutabi | 
ven VCN Redistributable 





Apache 2.4 Server Binaries 


Apache 2.4.x VCT 

Buit usieg C scurces fróm the ASF and OpenSSL on Visual Siido 2012 (VC11). 
Note: VC binaries do not run on Windows XP or Server 2005 

See teadme firi htmi fie for detaiis. 


Apache 2.4.18 hüpé2.419536-vciizip 80385 Download Locations 
KB 


With OpenSSL 1.02e, Zib 1.2.8 (mod fate), PCRE 8.38, APR 1.5.2, APR. 79 em 
UI15A, NS and TLO GNI trai SHA1 Checksum: 14b36c7b7b333f5c490853 1eb2bcd9d04bf82a6c. 











Apache 24.18 x64 htipd-2.4.18-x64-vc11zip 9,031.9 Download Locations 
KB 


with OpenSSL 1.0.2e, Zib 1.2.8 (mod defiate), PCRE 8.38, APR 1.52, APR- Gi e. 
DETEATNE II TUO SN NAA SHA1 Checksum: TaSbesebTe2583b630b3807780H0bófccBclcn3 





2.4 选择 下 载 Apache 2.4.18 x64 压缩 文件 包 





(5) 找到 Apache 2.4 Server Binaries 区 域 ， 选 择 Apache 
24x VC11 下 方 的 “Apache 2.4.18 x64” 链 接 ， 单 击 四 图 Es 
标 进入 下 载 页 面 。 把 文件 下 载 到 指定 的 文件 夹 中 ， 下 载 
完成 后 可 见 图 2.5 所 示 的 压缩 文件 包 。 同 时 ， 页 面 跳 转 OT 
到 图 2.6 所 示 的 选择 下 载 Visual Studio Redistributable 图 2.5 下 载 的 Apache 2.4.18 x64 
Packages 的 链接 页 面 。 压缩 文件 包 


FINE 如 果 计算 机 上 没有 安装 VC11， 就 选择 Microsoft Visual CH 2012 Redistributable 区 域 的 “Direct 
Download Link” 链 接 ， 进 入 图 2.7 所 示 的 页 面 下 载 并 安装 它 。 
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Apache Haus Downloads 
- Apsche22x Your download will start shortly... 
imis Frótens vive domes? 

Please use ms arednk or 

iy anamer mr 


Download Details 

DowisdName Apache 2418x864 

Download Descriptor: win OpenSSL 1 02e. Zib 1.2.8 (mod. aetate) PCRE 0.38. APR 1.5.2, APR UM 1.5.4, I6 and TLS SNI enabled 
Download Fiename: Mipó24 1826420 


Downoad Locator: Mii Germany miror 
Downoad Sponsor Mana Brand Deuschtang 


Visual Studio Redistributable Packages 


Microsoft Visual C++ 2008 Redistributable 
Microso Visual C++ 2008 Redstrbutabie Packages to be used lor our VC9 buads 


Microsoft Visual C++ 2008 SPI Redistribuable Package (x85) am — Oma 
KB. Download Link 
The Mcroson Visual Cee 2008 SP1 Redstrbuate Package (6) insta untme components 
ed to run applcatons developed with Visual C=+ on a computer 


Microsoft Visual C++ 2008 SP1 Redisribuable Package (x64) 


The Mroson Visual C-。 2008 SP1 Reditrbutae Package (64) nstals runtime comporonts 
ol Visual C» Libranes reqared to run appicatons developed wth Visual C«» or a computer 
that does not have Vuai C«« 2008 nstaled 


Microsoft Visual C++ 2012 Redistributable 
Merosot Vuai C** 2012 Redetrbutabi Packages to be used cr cur VC11 butas 


Microsoft Visual C++ 2012 Update 4 Redistributable Package WXBb x64) 62- — Ond 
Downoad 。 89 Dowiond Link 
MB 





The Merosof Visual Ce» 2012 Update 4 flection Re Package (X86 & x64) stas runtme 


2.6 选择 下 载 Visual Studio Redistributable Packages 的 链接 页 面 


Wi Merosot 


Great apps for Windows 


Find trae and paid apps to help you stay entertained, be procactus, or get 
estve 


Explore apps at the Windows Store > 


Visual C++ Redistributable for Visual Studio 2012 Update 4 


The Visual Ce + Redistributable Packages install runtime components that are 
required to run C+ + applications built with Visual Studio 2012 


Visual Studio 2015 


1ools for every developer and. 


图 2.7 Visual C++ Redistributable for Visual Studio 2012 Update 4 下 载 页 面 
2. 删除 本 地 机 上 Apache 以 前 的 版 本 


(1) 通过 “开始 ”一 “控制 面板 ”一 “程序 与 功能 ” 印 载 Apache 以 前 的 版 本 。 
(2) 删除 原始 Apache 文件 夹 及 其 所 有 内 容 。 
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© ndm 


2.2.2 E Apache 


1. 创建 安装 目录 


(1) 创建 安装 文件 夹 。 在 D 盘 上 建立 文件 夹 wamp。 
Q) 把 下 载 的 压缩 包 解压 到 wamp 文件 夹 下 , 并 修改 文件 夹 名 为 Apache24, 如 图 2.8 所 示 。 


~ 个 而 RAR > EIME(D) > wamp > Apache24 > conf > vb | 更 "conf P 

















SogouDownL ^ =r: i nanm nm * 
a Doms 20161/27 1959 zaa 
Í original 201611/27 1959 zea 
C) charsetconv 2015/12/11 2002 CONV Zit 
司 hapd 2016/1/27 2004 


Dee Q 2015/12/11 2002 
D einenpes osn 2002 


D opensstent 2015/12/3 2204 onr 





28 解压 缩 下 载 包 
(3) 在 D:/ wamp 下 创建 文件 夹 www, AEE 目录 ， 即 创建 站 点 的 根 目录 。 


2. 修改 配 置 文件 httpd.conf KA 
(1) 如 图 2.8 所 示 ， 找 到 文件 httpd. conf, JH Dreamweaver 打开 它 ， 如 图 2.9 所 示 。 

















id apache. ort/docz/2. 4 for analed information. 
In particular, see 
i <URL: http: //httpd. apache. ort/docs/2. /nod/Qirectives hta1> 
discussion of each confirirstion directive. 





de. They're here oily ss hints or reminders. If you are unsure 
it the online doce. You have been warned. 


N Configuration and logfile names: If the filenames you specify for nany 
of the server's control files begin with "/^ (or "drive./^ for Vini2). the 


# server az "/ust/local/apache2/logs/access, lot". vhereas "/logs/accezs lor" 
gil be interpreted az lote/access log - 


gott: Were tiienmes ato speeitisl vou mast ue forvard alui 

# instead of backslashes (e... ^c:/apache" instead of "c: Vapache^). 

3 It a drive letter iz omitted, the drive on which httpd. exe iz located 
H Will be used by default. It is recommended that you alvays supply 

| n saplicit arive letter im ubseluia pets to anid confusion 


" 
? Serverhoot. The top of the directory tree under which the server's 
X configuration. error, and log files are kept. 

H 


" 
# Muter: Allove you to set the mutex sechanies and mrtex file directory 
# for individual mutezes, or change the global defaults 

H 


3 Unconnent and change the directory if mutexes are file-based and the default 
# mutex file directory is not on a local disk or is mot appropriate for some 





2.9 用 Dreamweaver 打 开 httpd.conf 
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(2) 使 用 “编辑 ”菜单 中 的 “查找 替代 ”选项 ， 用 D:/wamp/ 蔡 换 c:/， 如 图 2.10 所 示 。 
修改 了 文档 中 的 ServerRoot, Documenroot, Directories, ScriptAlias 等 参数 ， 如 图 2.11 所 示 。 



































Dywamp/ ] 


DESXAS(O 





240 ”查找 替换 安装 路 径 
ServerRoot "D: /wamp/ Apache2d”™ 
| 219 mfServerName www. example. com: 80, 


DocumentRoot "D./wamp/www"* 
Directory “D: /wanp/ ww” A 





360 = Scriptålias 
<Directory D: Xwañp ápache24/ cgi-bin > 
2.11. 配置 文件 httpd.conf 的 修改 行 





(3) 保存 修改 后 的 httpd.conf 文 竹 并 关闭 记事 本 。 
3. 安装 Server 服务 


(0 碳 击 左下 角 的 “和 开始” 菜单， 选择“ 命令 提示 符 (管理 员 )” 选 项 ， 如 图 2.12 所 示 。 














图 2.12 ”以 管理 员 身 份 启动 “命令 提示 符 ” 
(2) 使 用 DOS 命令 改变 当前 工作 目录 ， 如 图 2.13 所 示 。 
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G) 输入 安装 服务 命令 ，httpd -k install -n "apache24"， 如 图 2.14 所 示 。 


C: WINDOWS 


D: Yed wanp/ap 




















ak] 








2.14 ”使 用 httpd 命令 安装 Apache24 服务 





LA 注 命令 行 下 方 的 报告 安装 成 功 ， 但 测试 配置 文件 httpd.conf， 提 示 有 些 错误 配置 需要 纠正 。 但 不 
4 Apache24 服务 的 启动 





2.2.3 启动 Apache 


使 用 ApacheMonitor 能 方便 地 启动 和 停止 Apache 服务 
(1) 找到 文件 夹 Apache24/bin 下 的 ApacheMonitor 程序 文件 ， 如 图 2.15 所 示 


v. dbd odbc-1.d 
v. Idap-1.di 


dul 








加 








2.15 ”找到 Apache24/bin 下 的 ApacheMonitor 应 用 程序 文件 





(2) 双击 图 2.15 所 示 的 ApacheMonitor 应 用 程序 文件 ， 可 在 任务 栏 的 右 
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EE. utres. HRE 2.16 所 示 的 Apache Service Monitor 窗口 。 
(3) 双击 右 侧 的 “Start” 按 钮 ， 其 内 的 红 点 变 成 绿色 ， 如 图 2.17 所 示 。 同 时 任务 栏 的 
右 端的 小 图 标 也 发 生 了 变化 ， 变 成 了 回 . 








Apache Service Monitor Apache Service Monitor 



































|Apache/2.4.18 (Win54) |Apache/2.4.18 (Win64) 
2.16 Apache Service Monitor 窗口 Æ 2.17 Apache Service Monitor 窗口 _Start 
2.24 IMiR Apache 


在 浏览 器 地 址 上 栏 输入 http://localhost/ 或 者 >http://127.0.0.1/， 按 Enter 键 ， 就 可 以 看 到 
如 图 2.18 所 示 的 页 面 ， 表 示 Apache 服务 器 已 安装 成 功 。 





图 2.18 在 浏览 器 士 测试 Apache 服务 


2.2.5 在 Windows 上 管理 Apache 

1. Windows 任务 栏 

Apache 的 默认 安装 会 将 Web 服务 器 作为 一 种 Windows 服务 来 运行 。 这 意味 着 在 开启 
计算 机 时 ， 它 会 自动 启动 ， 并 且 会 在 后 台 以 不 引 人 注 意 的 方式 运行 ，Apache 2.4 把 一 个 图 
标 ( 像 托盘 中 的 一 根 红色 羽毛 ， 带 有 一 个 白色 的 圆 点 ) 放 在 Windows 任务 栏 的 右 侧 ， 标 志 
Apache 的 状态 ， 运 行 时 ， 白 色 圆 点 中 出 现 一 个 绿色 的 右 指 箭头 贺 ， 停 止 时 ， 变 成 红色 贺 
点 图 ， 在 这 个 图 标 上 单 击 ， 出 现 如 图 2.16 所 示 的 界面 ， 有 Start( 启 动 )、Stop( 停 止 )、 
Restart( 重 启动 )3 个 选项 ， 可 以 很 方便 地 对 安装 的 Apache 服务 进行 上 述 操作 。 





2. Apache Service Monitor 


对 图 2.17 所 示 Apache Service Monitor(Apache 服务 管理 器 ) 窗 口中 的 要 素 说 明 如 下 : 
(1) 顶部 窗 格 显 示 安装 了 哪些 Apache 服务 ， 底 部 的 窗 格 显示 来 自 Apache 的 消息 ， 右 


er 
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侧 命 令 按 钮 提供 了 开始 、 停 止 或 重启 操作 。 
(2) “OK” 按 钮 : 将 Apache Service Monitor 最 小 化 为 任务 托盘 。 
(3) “Services” 按 钮 : 启动 “Windows 服务 ”窗口 。 
(4) "Connect" 按钮 : 连接 到 网 络 上 的 其 他 计算 机 ， 从 而 可 以 控制 安装 在 它们 上 面 的 服务 。 
(5) “Disconnect” 按 钮 : 断 开 与 网 络 上 的 计算 机 之 间 的 连接 。 
(6) “Exit” 按 钮 : 关闭 并 从 任务 托盘 中 删除 图 标 。 
3， 更 改 启动 首选 参数 或 者 禁用 Apache 


若 不 想 和 卸载 只 是 停 用 Apache， 可 以 将 其 切换 为 手动 操作 或 者 禁用 它 。 
(1) 在 Apache Service Monitor i O PAi; “Services” q, RA “FUR” > “ki 
pts" > A” A, HFF Windows 服务 窗口 ， 如 图 2.19 所 示 。 

































£249 Windows 服务 窗口 
(2) 双击 “apache24”,- 打开 “apache24 的 属性 ”对 话 框 ， 如 图 2.20 所 示 。 
G) 从 “启动 类 型 ”下 拉 列 表 中 选择 “自动 ”“ 手 动 ”或 “已 禁用 ”， 也 可 以 单 击 选用 
“服务 状态 ”下 方 的 相应 按钮 设 定 apache24 服务 的 状态 。 
Át RESULT apiche 24， 在 每 次 启动 计算 机 时 ， 状 态 图 标 都 将 显示 在 任务 栏 托盘 中 ， 


apache24 Bite Cites E 


2 





Ld mmm 
Exam apache24 


= Apachej24:18 Wins) 








Æ 2.20 apache 24 的 属性 
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4， 删 除 Apache 





(1) 在 “命令 提示 符 ” 窗 口中 ， 输 入 httpd -k uninstall -n "apache24"， 如 图 2.21 所 示 。 


图 2.21 使 用 httpd 命令 卸载 apache24 服务 























(2) 回 到 图 2.20 所 示 的 服务 窗口 中 不 见 了 apache24 服务 ， 如 图 2.22 所 示 。 








图 2.22 Windows 服务 窗口 卸载 了 apache24 服务 
2.3“ 安 装 和 配置 PHP 


2.3.1 安装 PHP 前 的 准备 
1. FA PHP 
(1) 在 浏览 器 的 地 址 栏 上 输入 http:/wwwiphp.net/， 进 入 图 2.23 所 示 的 界面 。 


Fast, flexible and pragmatic, PHP powers everything trom yo 


word. 


PHP 5.6.17 is available » OT Jan 2016 


The PHP development team announces ihe immediate avatibiity of PHP 56.17. This is a security relense. Several 
security bugs were fed in this release. AI PIIP 5 6 users are encouraged to upgrade to this version 


oues banners cun ba tound on 


3. The list of changes is recorded in the C? 





图 2.23 PHP 官方 网 站 主页 





(2) 找到 “Windows.php.net/download/” 链 接 , 单 击 进入 http://windows.php.net/download/ 
页 面 , 选择 适用 的 PHP 版 本 , 如 图 2.24 所 示 。 选择 PHP 5.6(5.6.17) 区 域 的 “VCI11 x64 Thread 
Safe” 的 ZIP。 
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PHP 5.6 (5.6.17) 


Download source code [3978] 

Vl1 x86 on Thread Safe (2016 Jan-06 23:35:49) 
* zo [202248] 

shal: 81586aab609172crndg1212788331624443dlc63 


* Debug Pack [oM] 
shal: daa93baf91837adc7BTeS24386763a81c6aesl 


VCII x86 Thread Safe (2016-Jan-06 23:36:02) 
* 2o [203208] 
shat: bs9Balafsllfe7bsdacdca7fe0szfdcbbcya 
* pibus pa [908] 
hatt 10af12d4e248634ee034bd95b63814353da6cd 


VC x64 Non Thread Safe (2016-20-06 23:35:50) 
Note: x64 bulds are curranty experimental 


* čo 2.5608] 
shot: 4dd70bb176fcl5b3W7c804955c918105cb1e596 


* Debug Pack [SO] 
shat: 9868d017cy0915b9d793086cBegEb85dd715 


11 x64 Thread Safe (2016 Jan-06 23:36:09) 
ote: 164 balds are currently experimental 





php-5.6.17-Win 
32-VCT1-x64 
2.24 在 windows.php.net/download/ 页 面 上 选择 下 载 的 PHP 版 本 2.25 下 载 的 压缩 包 


G) 将 文件 保存 到 硬盘 上 的 临时 文件 炎 中 ， 如 图 2.25 所 示 。 
2， 删 除 本 地 机 上 PHP 以 前 的 版 本 


(1) 备份 Windows 文件 夹 (主要 是 php.inD) 和 .System32 子 文件 夹 中 任何 与 PHP 相关 的 文 
件 (php.ini、php4ts.dlls、php5ts.dll 和 以 php 开头 的 DLL 文件 )。 

(2) 删除 Windows 文件 夹 (主要 是 php.inD 和 System32 子 文件 夹 中 任何 与 PHP 相关 的 文 
件 (php.ini、php4ts.dll、php5ts.dll 和 以 php 开头 的 DLL 文件 )。 

(3) 删除 Windows 文件 夹 的 libmysql.dll 的 副本 文件 。 


2.3.2 安装 PHP 


将 下 载 的 文件 php-5.6.17-Win32-VC11-x64.zip 解压 缩 到 wamp 文件 夹 下 ， 修 改 文件 夹 
名 为 php。 查 看 php 文件 夹 内 容 ， 有 39 个 文件 和 文件 夹 ， 如 图 2.26 所 示 。 


E fopa D phoisi development 
E saut C] phpini-producion 
E esa i phpSapache2 Adi 
phpSembed ib 
phpsphpdbg dl 
 phpSts.dil 
e Bipec 
S itesizat Biehodbg 
Giibendendi E phe Boh vin 


394-:B ipm 1428 310KB 





图 2.26 查看 解压 缩 后 的 php 文件 夹 内 容 
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2.83 Big PHP 
1. 修改 php.ini 


1E D:/wamp/php 中 找到 “php.ini-development ”文件 , 复制 该 文件 , 并 重 命名 为 “php.ini”， 
可 见 图 标 发 生 了 变化 ， 可 以 通过 任何 文本 编辑 器 打开 它 ;， 如 在 Dreamweaver 中 打开 它 ， 做 
如 下 几 处 修改 ， 如 图 2.27 所 示 。 
































图 2.27 php.ini 的 修改 行人、 


(1) 找到 第 734 行 ， 如 图 2.27 所 示 ， 修 改 为 extension_dir="D:/wamp/php/ext"， 这 是 一 
个 文件 夹 的 名 称 ，PHP 将 在 这 个 文件 夹 中 寻找 需要 的 扩展 。 

(2) 找到 php.ini 中 的 第 878 T, 看 到 一 个 名 为 extensions 的 长 列表 ， 这 是 Dynamic 
Extensions 区 域 的 开始 行 ， 它 们 大 多 数 被 作为 注释 ( 行 首 是 “; ”)， 这 些 扩展 可 以 向 PHP 的 
核心 功能 中 添加 额外 的 特性 。 可 以 在 任何 时 间 户 用 其 中 的 任何 扩展 ， 即 选择 要 启用 的 扩展 
所 在 行 的 开始 处 删除 分 号 ， 如 图 2:27. 所 示 加 载 所 要 的 扩展 。 


Qras v, AT 

extension- php gd2.dll: 启用 GD, 库 ， 使 用 它 能 操作 图 徐 . 

extension- php_mbstring.all: 一 启用 对 多 字 节 字符 集 的 支持 ， 若 在 英文 环境 下 ， 则 不 需要 这 个 扩展 ， 目 
前 MySQL4.1 以 上 版 本 用 UTF-8 存储 字符 ，UTF-8 就 是 多 守节 字符 集 . 

extension= php: mysql.dll: 启用 与 MySQL 相关 的 代码 库 。 

extension= php mysqli.dll: 启用 MySQL Improved 扩展 . 

(3) 找到 第 1416 行 ， 如 图 2.27 所 示 ， 删 除 行 首 的 分 号 “; ”， 并 把 引号 中 的 设置 改 为 本 
地 机 的 Temp 文件 夹 ， 大 多 数 Windows 是 Ci\windows\temp。 

(4) 保存 文件 php.ini。 

2. 把 PHP 添加 到 Windows 启动 过 程 

如 果 启 用 了 扩展 模块 ， 就 要 指明 模块 的 位 置 ， 否则 重启 Apache 的 时 候 会 提示 “ 找 不 到 
指定 模块 ”的 错误 ， 这 里 介绍 一 种 最 简单 的 方法 ， 直 接 将 PHP 安装 路 径 、 相 应 的 ext 路 径 
指定 到 Windows 系统 路 径 中 。 

(1) 选择 “开始 ”一 “控制 面板 ”一 “系统 ”选项 ， 进 入 “系统 ”对 话 框 ， 如 图 2.28 所 示 。 





















































2.28 “系统 ”对 话 框 
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(2) 单 击 “ 高 级 系统 属性 ”链接 ， 进 入 “系统 属性 ”对 话 框 ， 选 择 “ 高 级 ”标签 ， 











到 2.29 所 示 。 








Q) 单 击 “ 环 境 变量 ”按钮 ， 弹 出 “环境 变量 ”对 话 框 ， 在 “系统 变量 ”区 域 ， 找 到 





“Path” 变 量 ， 如 图 2.30 所 示 。 


USERPROFILESAppDatalLocal Temp. 
SSUSERPRORILER AppDatalLocal Temp. 


WN 

















图 2.29 “系统 属性 ”对 话 框 图 2.30 设置 环境 变量 
(4) 单 击 “ 编 辑 ” 按 钮 , -弹出 “编辑 系统 变量 ”对 话 框 ， 选 中 列表 栏 





~N 


如 


中 的 某 个 选项 ， 


再 单 击 “编辑 文本 ”按钮 ,， 参看 图 2.32， 弹 出 “编辑 系统 变量 ”对 话 框 ， 在 “变量 值 ” 文 
本 框 内 单 击 ， 并 把 光标 移 到 现 有 值 的 末尾 ， 输 入 分 号 ， 在 其 后 输入 PHP 文件 夹 的 名 称 


(;D:\wamp\php;D:\wamp\php\ext), WPA 2.31 rz: 


LN 注 在 现 有 值 司 面 或 在 新 路 径 名 中 应 该 不 含 空格 ， 





Path 











3SYSTEMROOT9ASystem32WíndowsPowerShell 1.0 AVANA a A] 











[e] 





2.931 编辑 环境 变量 _ 编 辑 文本 





(5) 单 击 “确定 ”按钮 ， 返 回 “ 编 辑 系统 变量 ”对 话 框 ， 如 图 2.32 所 示 ， 可 见 添加 的 





值 。 依 次 单 击 “ 确 定 ”按钮 ， 关 闭 所 有 对 话 框 。 


W 
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%SYSTEMROOT%\System32\WindowsPowerShell\1.0\ 


DAwamp\php\ext 














图 2.32 编辑 环境 变量 -编辑 文本 后 
启动 计算 机 时 ，Windgws 操作 系统 将 知道 在 哪里 找到 所 有 必要 的 文件 来 








这 样 ， 当 
运行 PHP。 z 
3. 配置 Apache 与 PHP 协同 工作 Xp. 


修改 Apache 的 配置 文件 httpd.conf， 将 PHP DJ module 方式 与 Apache 相 结合 ， 使 PHP 
融入 Apache. 在 Dreamweaver 中 打开 文件 httpdieonf， 如 图 2.33 所 示 ， 修 改 以 下 几 处 代码 。 





D. 7wampyphpyphp5apache2_4.dl] 









atnl index.php index. htm 





-httpd-php ,php . html . htm 
图 2.33 配置 文件 httpd.conf 的 修改 行 


(1) 加 载 PHP 5 模块 。 找 到 第 178 行 ， 这 是 一 个 以 LoadModule 开头 的 项 目 列表 ,在 最 
后 一 行 后 ， 添 加 两 个 新 行 ， 一 行 指出 以 module 方式 加 载 PHP， 另 一 行 指明 PHP 的 配置 文 
件 php.ini 的 位 置 ， 如 图 2.33 所 示 。 
1 

QD de PHP 安装 目录 有 空格 ， 如 "C:\Program Files"， 那 么 在 此 处 添加 目录 路 径 可 能 会 报错 ， 原 因 是 
Apache 会 把 空格 作为 两 个 参数 的 间隔 。 

解决 方法 一 : 重新 把 PHP 安装 到 其 他 目录 ， 注 意 不 要 有 空格 。 

解决 方法 二 : 把 C:\Program Files 变 为 C:\Program~Files， 这 样 实际 目录 变 成 了 C:\Program。 

Q 表示 PHP 安装 在 C:\php5 中 ， 注 意 路 径 名 中 使 用 正 斜 杠 “/”。 

Q) 设置 首页 执行 的 顺序 。 找 到 第 278 行 ， 在 行 尾 追 加 如 图 2.33 所 示 的 代码 ， 表 示 主 
页 执行 的 顺序 。 
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(3) 添加 可 以 执行 PHP 的 文件 类 型 。 找 到 第 406 行 ， 添 加 一 行 ， 定 义 扩展 来 指定 媒体 
的 类 型 ， 如 图 2.33 所 示 。 


Qras 
也 可 以 加 入 更 多 ， 实 质 就 是 添加 可 以 执行 PHP 的 文件 类 型 ， 如 
AddType application/x-httpd-php .html 
AddType application/x-httpd-php .htm „html 或 htm 文件 也 可 以 执行 PHP 程序 了 
AddType application/x-httpd-php .txt 让 普通 的 文本 文件 格式 也 能 运行 PHP 程序 
(4) 保存 文件 httpd.conf。 


2.3.4 测试 PHP 








(1) 在 指定 的 服务 器 上 创建 测试 文件 。 
(D 在 Dreamweaver 中 编写 如 下 代码 。 


<?php g | 
phpinfo (); 
?> K5 


(Q2) 以 phpinfo.php 为 名 ， 把 文件 保存 在 n Janpwww 文件 夹 下 。 
(2) 确认 已 经 启动 了 Apache. “~ 


一 


(3) 打开 浏览 器 ， 在 地 址 栏 输入 hitp://127.0.0. L/phpinfo.php. 
图 2.34 所 示 的 界面 显示 的 是 PHP 的 配置 信息 。， 于 人 一 
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MSVC11 (Visual C++ 2012) 









































2.34 测试 PHP 的 配置 信息 
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24 “安装 和 配置 MySQL 


2.4.1 安装 MySQL 前 的 准备 


1. 下 载 MySQL 


(1) 在 浏览 器 的 地 址 栏 上 输入 http:/www.mysql.com/， 进 入 MySQL 官方 网 站 的 主页 ， 
“Downloads ”标签 ， 进 入 如 图 2.35 所 示 的 页 面 。 











Register 


aj 


Enterprise MUT M 


MySQL.com. Downloads Developer Zone. 


Contact Sales MySQL Downloads 
USA: 21-866-221-0634 


Canada: +1-866-221-0634 MySQL Enterprise Edition (commercia) _ 


MySQL Enterprise Edition includes the móst comprehensive set of advanced features and management 
Germany: +4989 143 01280 tools for MySQL. 
France: 333 1 57 608357. 
kaly: +390224959120 + MySQL Database 
UK: +44 207 553 8447 » MySQL Storage Engines (lànoDB, MyISAM, etc.) 
» MySQL Connéctors (DBT, ODBC, .Net etc.) 
Japan: 0120-065556 


China: 10800-811-0823. * MySQL Replication. 
India: 0008001005870 «- MySQL Fabric 





图 2.35 MySQL -Downloads 


(2) Aih FIRER “Community” k, HUR 2.36 所 示 的 页 面 ， 再 单 击 左 侧 
栏目 上 的 “MySQD Community Server” 链 接 。 





Contact MySQL | Login | Register 
a] 


Enterprise Community 


MYSQL on Windows 


MYSQL Yum Repository 


MySQL Community Server P1) 


MYSQL Enterprise Edition 


| (commercia 
MySQL SUSE Repository. MySQL Community Server is the world's most popular 
open source database. MySQL Enterprise Edition includes the 
M pity Server most comprehensive set of advanced. 
DOMNUNND, features and management tools for 
MySQL. 


httpy/devmysql com/downloads/mysql/ MySQL Cluster (sp Learn More» 


MySQL APT Repository 


MySQL Cluster 











图 2.36 MySQL 官方 网 站 _Downloads_Communcity 
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(3) 找到 “Looking for previous GA versions?” 区 域 ， 选 择 MySQL Community Server 


5.6.x Windows (x86,64bit), ZIP Archive 版 本 , 单 击 其 后 的 “download ”链接 下 载 , 如 图 2.37 
所 示 。 





Contact MySQL | Logn | Register 
a 





Enterprise Community Yum Reposit 


MYSQL on Windows 


Download MySQL Community Server 


MES UHR MySQL Community Editionis a freely downloadable version of the world's most 


MySQL APT Repository popular open source database that s supported byan acie communnyofopen MYSQL open soiree son 
source developers and enthusiasts. provided ur 


MYSQL SUSE Repository OEMs ISVs and VARS can 
MYSQL Cluster Community Edition is available as a separate download. Tbe feaso®h, purchase commercial icai 
MYSQL Community Server for this change is so that MySQL Cluster can provide more frequent updates aid 


din support using the latest sources of MySQL Cluster Carrier Grade'Edjori, 
J Custer 


Wsa Fabne @ ronan piatom support pdates 


MySQL Router. 
Online Documentation: Looking for previous GA versions? 


MYSQL Utilities N 
Installation Instructions, Documentation ànd ChangWiStory - My mmuni 9 


MYSQL Workbench. for the MySQL 5:7 Generally Availale (GA) alea - MySQL Communiy Seir S. 
"nstallation instructions, Docurientauón ang Change History 
meray Avaliife (GÀY Release 


AAAI Fannactars = Archived versions » 


httpy/devmysqleom/downiosds/mysal/5.6 htmisdownloads "95015 6 Ge 





2.37 选择 MySQL Community Server 5.6.x 


(4) 在 MySQL Installer 5.6 for Windows 区 域 ， 选 择 Windows (x86,64-bit), ZIP Archive 
版 本 ， 单 击 其 后 的 “download” 链 接 下 载 ， 如 图 2.38 所 示 。 


Enterprse 。 Copy wu güpostoly, Widow we 4» Developer Zone. 


MySQL Community Server 5.6.28 


Select Version: Looking for the latest GA version? 
5.6.28 ~ 
Select Platform: 


Recommended Download: 





MySQL Installer 5.6 
ges for Windows 


ee I 
numm 


Windows (x86, 32-bit), MySQL Installer MSI 


Other Downloads: 


Windows (x86, 32-bit), Zi Archive ssa su E 


mpgs 28 mm og MOS: 5635024534262 5455 £04399eaaA9435 | 


Windows (x86, 64-bit), ZIP Archive 


p Secad7a61b5694 | 
grate 








2.38 MySQL Community Server 5.6.28 FKH 
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(5) 选择 非 登 录 非 注册 的 下 载 方式 ， 单 击 下方 的 “No thanks, just start my download.” 
链接 ， 如 图 2.39 所 示 。 


Contact MySQL | Login | Register 





porem Begin Your Download - mysql-5.6.28-winx64.zip 
MYSQL Yum Repost 
SQ vum upan Login Now or Sign Up for a free account. 
MySQL APT Repository. An Oracle Web Account provides you with the following advantages: 
MYSQL SUSE Repostory « Fastaccessto MYSQL software downloads 
+ Download technical white Papers and Presentations 
+ Postmessage in the MYSQL Discussion Forums 
Ms user ^ Report and vack bugs nthe MYSQL bug system 
AEREE Comment in the MYSQL Documentavon 


MYSQL Community Server 


MYSQL Router 
MySQL Utilties. Sig] Up > 
MySQL Workbench 


MySQL Connectors 


MySQL.com is using Oracle ssb for autfienbcaton. If you already have an 
POETE Oracle Web account, cick ha Login ink, Otherwse you can signup for a free 
account by clicking thè Sign Us nk and following the instructions. 


No thanks, just tart my darimload. 





图 2.39 选择 非 登 录 非 注册 的 下 载 方式 
200) (9 遵循 页 面 指导 把 文件 下 载 到 硬盘 上 的 临时 文件 夹 
m SA 如 图 2.40 所 示 。 
NN 2， 删 除 本 地 机 上 MySQL 以 前 的 版 本 
(1) 备份 数据 ， 以 后 可 以 恢复 这 些 数据 。 


(2) 停止 MySQL 服务， 如 在 Windows“ 命 令 提 示 符 ”窗口 ， 输 
240 下 载 的 MySQL 入 命令 ; 


i 





mysal-5.6.28-wi 
nx64 














“>cd c:\mysgl\bin 
c:\mysql\bin>NET STOP MySQL 


(3) 删除 MySQL 服务 ， 如 输入 命令 : 
c:\mysql\bin>mysqlld --remove 
(4) 也 可 以 通过 “控制 面板 ”一 “程序 与 功能 ”卸载 MySQL 现 有 的 版 本 。 
2.4.2 安装 MySQL 
1. 创建 安装 目录 
将 下 载 的 文件 mysql-5.6.28-winx64.zip 解压 缩 到 wamp 文件 夹 下 ， 修 改 文件 夹 名 为 
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mysql. ÆA mysql 文件 夹 内 容 ， 有 3 个 文件 和 S 个 文件 夹 ， 如 图 2.41 所 示 。 


sanm 


2016/1/29 1442 2i 
2016/1/29 1442 
include 2016/1/29 14:42 





ib 2016/1/31 1008 
share 2016/1/29 1442 
D coping 2015/11/29 20:16 
E) myrdefauk 2015/11/29 2033 
[D README 2015/11/29 2016. 


个 项 目 。 远 中 1 个 项 目 1.11 KB 
图 2.41 ”查看 解压 缩 后 的 MySQL 文件 夹 内 容 
2. 修改 配置 文件 my.ini 


在 D:\wamp\mysq! 中 找到 “my-default.ini” 文 件 ， didici, 并 重 命名 为 “my.ini”， 
在 Dreamweaver 中 打开 它 ， tailed 如 图 2. 42 Bio. 














B2: 42 my.ini 的 修改 行 


(1) 找到 第 18 行 ， 如 图 2.42 所 示 , 修改 为 basedikZD- amp mysql, 这 里 添加 的 是 存放 
mysql 的 目录 。 

(2) 找到 第 19 fT. 如 图 2. 42 所 示 ， 修 改 为 ditadir-D: \wamp\mysql\data， 这 里 添加 的 是 
存放 mysql 下 data 的 目录 ， 用 户 所 建 的 数据 库 文 件 就 存储 在 这 个 文件 夹 中 。 


LN 注 将 前 面 的 注释 符 “jp" 去掉， 注意 这 里 的 针 杠 是 反 针 杠 “\”。 








(3) 找到 第 20 行 ， 如 图 2.42 所 示 ， 修 改 为 port=3304， 这 里 添加 的 是 绑 定 3306 端口 。 

(4) 找到 第 29 行 ， 添 加 一 行 ， 输 入 max_connections=200， 如 图 2.42 所 示 ， 这 里 添加 
的 是 限定 连接 数据 库 的 最 大 数目 。 

(5) 保存 文件 php.ini。 

3. 把 MySQL 添加 到 Windows 启动 过 程 

参考 2.3.3 节 中 “2. JE PHP 添加 到 Windows 启动 过 程 ” 追加 系统 的 环境 变量 。 


path= ;D:\wamp\mysql\bin 





4. 安装 MySQL 服务 


(1) 启动 “命令 提示 符 (管理 员 )” 应 用 程序 ， 改 变 当 前 目录 为 D:\wamp\mysqhbin, 41 
图 2.43 所 示 。 
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图 2.43 ”改变 当前 目录 
(2) 执行 安装 服务 命令 :mysqld-install， 如 图 2.44 所 示 。 








2.4.3 启动 MySQL 


(1) 执行 启动 服务 命令 : 如 图 2.45 所 示 。 





图 2.45 执行 启动 服务 命令 


(2) 依次 选择 “计算 机 管理 ”一 “服务 和 应 用 程序 ”一 “服务 ”选项 ,可 以 看 到 MySQL 
服务 ,如 图 2.46 所 示 。 





图 2.46 计算 机 管理 的 服务 窗口 


(3) Hih “MySQL”, HABI 2.47 所 示 的 对 话 框 , 可 以 管理 MySQL 服务 。 例如 ， 从 “ 启 
动 类 型 ”下 拉 列 表 中 选择 “自动 >“ 手动 ”或 “已 禁用 ”， 也 可 以 单 击 “ 服 务 状态 ”区 域 下 
方 的 按钮 设 定 MySQL 服务 的 相应 状态 。 


44 
SA 


CQ aea nonumm 
© i 





可 执行 文件 的 路径: 
DAwamp\mysqN\bin\mysqld MySQL 








BIRRE): 





247 MySQL 的 属性 
2.4.4 测试 MySQL SX Y 
(1) 在 浏览 器 的 地 址 栏 上 输入 hitp:/127.0.0. L/phpinfo.php. 可 见 如 图 2.34 所 示 的 页 面 ， 
向 下 滚动 ， 可 见 图 2.48 所 示 的 页 面 ， 看 到 了 mysql 和 mysqli， 说 明 PHP 加 载 MySQL 到 已 
开启 的 模块 了 。 
























































mysqli 


mysqind 5.0.11-dev - 20120503 - Sid: 30688b6bbc30936a!3ac34idd4b7b5b7871e5555 $ 


























图 2.48 PHP 配置 信息 中 已 加 载 的 模块 
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(2) 在 Dreamweaver 中 编写 代码 : 


«?php 
$conn-8mysql connect ("localhost","root",""); 
if ($conn) { 
echo "连接 成 功 "; 
}else{ 
echo "连接 失败 "7 


37> 
(3) 以 link.php 为 名 ， 把 文件 保存 在 D:/wamp/www 文件 夹 下 。 


(4) 在 浏览 器 的 地 址 栏 上 输入 : http://localhost/ink.php 回 车 ， 可 见 图 2.49 所 示 的 页 
表明 连接 成 功 。 











FI ^ localhost/lini-php 





图 2.49 数据库 连接 


2.4.5 安装 phpMyAdmin 
1. FR phpMyAdmin 


(1) 在 浏览 器 的 地 址 栏 上 输入 .httpYWWww.phpmyadmin.net/， 进 入 如 图 2.50 所 示 的 
phpMyAdmin 官方 网 站 的 主 
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Bringing MySQL to the web 
phpMugAdmin 


About Diamond sponsor 
phpMyAdmin is a free software tool written in PHP, intended to handle the administration of MySQL over the Web. 
phpMyAdmin supports a wide range of operations on MySQL and MariaDB. Frequently used operations (managing 


databases, tables, columns, relations, indexes, users, permissions, etc) can be performed via the user interface, while CURE 
you still have the ability to directly execute any SQL statement. 


phpMyAdmin comes with a wide range of documentation and users are welcome to update our ~ 
wiki pages to share ideas and howtos for various operations. The phpMyAdmin team will try to 
help you if you face any problem; you can use a variety of support channels to get help. 
phpMyAdmin is also very deeply documented in a book written by one of the developers — Navicat 
A^ Mastering phpMyAdmin for Effective MySQL Management, which is available in English and - - 
Spanish. 
phpMyAdmin Intelligent MySQL GUI 
arter 


To ease usage to a wide range of people, phpMyAdmin is being translated into 72 languages and — Full-featured Database Manager 


supports both LTR and RTL languages. 


phpMyAdmin is a seventeen-year.old project with a stable and flexible code base; you can find 


out more about the project and its history and the awards it eamed. When the project turned 15, Platinum sponsor 
we published a celebration page. 


The phpMyAdmin project is a member of Software Freedom Conservancy. SFC is a not-for-profit organization that helps. 
promote, improve, develop, and defend Free, Libre, and Open Source Software (FLOSS) projects. 


ol; WebHosting 
Secrethevesled 


hpy/wwwphpmyadminnetdownloada/ Y" conservancy 








2.50 phpMyAdmin 官方 网 站 的 主页 
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(2) 单 击 导航 栏 上 的 “Download ”链接 , 进入 Download 页 面 , 找到 phpMyAdmin4.5.4.1 
区 域 ， 单 击 “phpMyAdmin-4.5.4.1-all-languages.zip” 链 接 下 载 ， 如 图 2.51 所 示 。 
(3) 进入 下 载 过 程 ， 完 成 后 的 图 标 如 图 2.52 所 示 。 
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Bringing MySQL to the web 


phpMuAdmin 


Download 


usually the quickest way to an updated installation. Please contact your OS vendor for more information. Some additional 
information is also available in our documentation. If you just want to try phpMyAdmin in a virtual machine, you might want 
to check the available software appliances which provide phpMyAdmin. 


It you do not find a suitable package or wish to install your own phpMyAdmin, you can download one of the following kits. 
Please note that each version has requirements for he minimum PHP and MySQL versions. 


Since Juy 2015 alı phpMyAdmin releases are cryptograpticaly signed by e releasing developer You shouid ver fh 
the signature matches the archive you have downloaded. Verification instructions are placed in our documentation in the 
Vorifying phpMyAdmin releases chapter. 


phpMyAdmin 4.5.4.1 


Released 2016-01-29, seo release notes for details. 
Current version compatible with PHP 5.5 to 7.0 and MySQL 5.5. 


File. Size. Verification. 4 ^S 
DhoMvAdmin-iS4alanguages7z 5.7 MB [PGP] [MDS] [SHAT] 
DhpMyAdmin-4 5.4 1-al-languagos tarbz2 7.5 MB [PGP] [MOS] [SHAI] ~ h 
Janguanestarqz 9.4 MB [PGP] IMDS] [SHAT] 
X: 5.5 MB [PGP] [MDS] [SHAI 
ip — 100MB [PGP] [MOS] [SEAT] ep z 
3.9 MB [PGP] [MD5] [SHAI l phpMyAdmin-4. 
phpMyAdmin-4 5 4 1-enqlish tar bz2 46 MB [POP] [MOS] [SHA 1] 5,4.1-all-langua 
A '-english tar. 54 MB [PGP] MIDST [SHAT] E Fl 


2.51. TF phpMyAdmin 的 网 页 2.52 下载 的 压缩 文件 





2， 安 装 phpMyAdmin 
(1) 把 下 载 的 压缩 文件 phpMyAdmin-4.5.4.1-all-languages.zip 解压 缩 到 D:wampWwww 


下 ， 重 新 命名 为 phhpMyAdmin， 如 图 2.53 所 示 。 








~ P lla wamp > www 
wamp LJ phi 
了 了 Apache24 [ link.php 
C phpinfo.php 


> phpMyAdmin y 
3 个 项 目 ”选中 1 个 项 目 





253 ”解压 缩 后 的 文件 夹 
(2) 打开 文件 夹 phppMyAdmin， 可 见 包含 了 如 图 2.54 所 示 的 内 容 。 
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图 2.54 phpMyAdmin XR | 
3， 配 置 phpMyAdmin CA 
(1) phpMyAdmin 配置 文件 。 由 于 phpMyAdmin 版 本 的 差异 ， 配 置 文件 可 能 是 
config.inc.php 或 config.default.php, 位 于 当前 目 录 下 或 者 libraries 子 目 录 内 。 有 时 找 不 到 
这 样 的 文件 ， 就 需要 复制 config.sample.inc.php, 再 重 命名 为 config.inc.php。 本 版 本 的 配 
党 文件 是 在 libraries 下 的 config.defauitphp, E Dreamweaver 中 修改 如 图 2.55 所 示 的 




















内 容 。 E^ 






localhost” 


2.55 ”修改 phpMyAdmin 的 配置 参数 


(2) 配置 访问 网 址 :在 第 39 行 的 Scfg[PmaAbsoluteUri] = "填写 phpMyAdmin 的 访问 
网 址 ， 默 认为 http:WlocalhostphpMyAdmin/， 保 留 为 空 即 可 。 

(3) 配置 MySQL 主机 信息 : 

© 在 第 125 fT ll) Scfg['Servers'][Si]['host']-"localhost': 填写 localhost 或 MySQL 所 
在 服务 器 的 主机 名 或 他 地址。 车 MySQL 和 该 phpMyAdmin 在 同一 服务 器 ， 则 填写 localhost 
或 127.0.0.1。 

© 在 第 132 行 的 Scfg['Servers'][$i][port] = "; 填写 MySQL 端口 ， 默 认为 3306， 保 留 
为 空 即 可 。 若 安装 MySQL 时 使 用 了 其 他 的 端口 ， 需 要 在 这 里 填写 。 

@ 在 第 188 行 的 $cfg['Servers'][$i]['connect type']-"; 填写 连接 到 MySQL 服务 器 的 类 








CQ aea nonumm o 
© 一 nal ^ 


型 ， 可 以 是 tcp EX socket， 默 认 值 为 tcp。 

(4) 设置 MySQL 的 用 户 名 和 密码 : 

C) 在 第 267 行 的 Scfg['Servers'"][$i]['user]='root'; 填写 MySQL 访问 phpMyAdmin 使 
的 MySQL 用 户 名 ， 默 认为 root。 

(2) 在 第 267 行 的 $cfg ['Servers'][$i]['password]="; 填写 对 应 上 述 MySQL 用 户 名 的 密码 。 
解压 缩 安 装 没有 设置 密码 。 

图 在 第 535 行 的 Scfg['Servers'][$i]['AllowNoPassword]=true; 改写 为 tue， 人 允许 使 用 无 
密码 。 
Ris 

在 开发 阶段 或 资源 独占 时 ， 可 以 考虑 不 用 密码 。 或 使 用 专用 文件 管理 ， 省 去 记忆 的 负担 。 

(5) 设置 认证 方法 : 在 第 238 行 的 $cfg[" mima tele 'cookie' 考虑 到 安全 
的 因素 ， 建 议 这 里 填写 cookie。 


Qras TAN 
有 4 种 认证 模式 可 供 选 择 : config. cookie, http. signon, ^ 
(D config 方式 : 是 一 种 简单 且 使 用 得 比较 多 的 一 种 庆 证 方式 ， 用 户 名 和 密码 都 配置 在 config.inc.php P. 
回 cookie 方式 : 用 户 Aa AAEE. copie] P 直到 会 话 (session) 关 闭 ， 关 闭 之 后 保存 在 cookies 
里 面 的 密码 会 被 删除 掉 。 - 
© http 方式 : 允许 通过 HTTP-Auth 认证 用 合法 的 MySQL 用 户 登 录 ， 当 PHP 安装 模式 为 Apache 时 ， 
可 以 使 用 http 和 cookie, AX phpMyAdmiii 需要 输入 用 户 SA 
图 signon zz X: 单 点 登录 模式 。 L 


(6) 设置 短语 密码 ;在 第 102 TE Y. 如 果 认 证 方法 设置 为 cookie， 
就 需要 设置 短语 帘 码 。 当 密码 为 空 时 ， 可 以 设置 为 空 ， 否 则 应 设置 不 为 空 的 字符 串 作 为 短 
语 密码 ， 不 然 会 在 登录 phpMyAdmin 时 提示 错误 。 
LAN 注 这 个 文件 是 用 PHP 写 的 ， 以 S 开 头 的 字符 串 表 示 一 个 变量 ， 通 过 对 变量 的 赋值 来 改变 其 中 的 配 

置 ， 在 运行 中 出 现 的 各 种 问题 可 通过 互联 网 查询 ， 获 取 帮 助 。 

(7) 保存 文件 。 

4. 测试 安装 的 phpMyAdmin 

(1) 在 浏览 器 上 的 地 址 栏 输 入 http;/localhos/phpMyAdmin/, HEA til 2.56(a) 所 示 
phpMyAdmin 的 欢迎 和 登录 界面 。 

(2) 选择 语言 为 中 文 -Chinese simplified， 如 图 2.56(b) 所 示 。 

(3) 输入 用 户 名 和 密码 后 ， 进 入 如 图 2.56(c) 所 示 的 界面 。 
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图 2.56 phpMyAdmin 的 欢迎 和 登录 界面 
(4) 单 击 “ 执 行 ”按钮 ， 进 入 如 图 2.57 所 示 的 界面 。 这 是 pmahomme 风格 的 页 面 。 从 
“主题 ”下 拉 列 表 中 选择 ， 可 以 进入 Origina 风格 的 页 面 ， 如 图 2.58 所 示 。 
phpMyAdmin 3 


PI LISCE] 
Ahn mee 





Gw 


a * 最 务 中 类 型 MySQL 
^ 服务 器 版 本 : 5.628 - MySQL Community Server 
B-a performance schema. (GPL) ie z 
j test - «PSOE: 10 


* BA : root@localhost 
* BESSER: UTF-8 Unicode (utf8) 


ame 7 p VX 
EXC Y xe * IBS : localhost via TCP/IP 
H 





AN 
NN 


NN - re 
^| ozs: [n 
* Apache/24.18 (Win64) PHP/5.6.17. 


+ BRERAREE : libmysql - mysqind 5.0.11- 
dev - 20120503 - $id: 


3c688b6bbc30d36af3ac34fdd4b7b5b787165555 
$ 





* PHP 扩 展 : mysqll dj 
PHP 版 本 : 56.17 


phpMyAdmin 


版 本 信息 4541 
E 














«i, phpMyAdmin 庆功 和 尚未 完全 设置 SIDEFRE, EHER, 
或 者 也 可 以 去 甘 个 数据 这 的 “ 报 作 ”选项 卡 那 时 进行 设置 . 


2.57 phpMyAdmin 4.5.4.1 页 面 _pmahomme 风格 
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图 2.58 phpMyAdmin 4.5.4.1 的 页 面 _Original 风格 


2.5 AppServ 组 件 安装 


2.5.1 安装 AppServ 前 的 准备 
(1) 下 载 AppServ。 


@ 在 浏览 器 的 地 址 栏 上 输入 http//www.AppServnetwork.com/download, 进入 如 图 2.59 
所 示 的 AppServ 官方 网 站 的 Download 页 面 5 





Download 
ES -一 .Emo 一 


AppServ 8.0.0 
* Apache 2418 
+ PHP 56:17 
PHP 7D2 





Can't run on Windows XP or Windows Server 
* MYSQL S730 2003 


+ phpMyAdmin 4 53.1 
This version can swith PHP version 














* Support TLSSSL or https by Spear Shortcut -> PHP Version 
«Can switch the PHP version as you need [oer re erg 
—— 
riae rong mph ré tds) 
e" ee A En 
Mtr 和 多 加 
DOWNLO. appserv-w 
in32-8.0.0 
图 2.59 AppServ 官方 网 站 的 下 载 网 页 图 2.60 下载 的 软件 包 

















© 单 击 “Download” 按 钮 ， 开 始 下 载 ， 完 成 后 的 图 标 如 图 2.60 所 示 。 
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© 下 载 过 程 中 ， 页 面 跳 转 到 http://sourceforge.net/projects/appserv， 页 面 中 部 如 图 2.61 
所 示 ， 单 击 “AppServ” 链 接 ， 可 以 了 解 更 多 关于 AppServ 的 内 容 。 














An easy to install Apache distribution containing MySQL, PHP. | Dowo e] Eroa 


and Perl 


E Firebird 
A powerful, cross platform, SQL database system 
Ed 1 » 
lo i; Thé easy way to configure Apache, PHP, and MySQL! 


图 2.61 http://sourceforge.net/projects/appserv 页 面 中 部 









@ 选择 图 2.59 所 示 的 AppServ 官方 网 站 导航 栏 上 的 “Version History” 链 接 ， 可 见 
图 2.62 所 示 的 早期 版 本 ， 可 根据 计算 机 的 配置 下 载 合适 的 版 本 。 





Download Version History. 





Version History 
E ee 5» Beso 
AppServ All Version for who need to downgrade or choose old version for any situation. 


This page is for AppServ versions which have reached EOL(end of [ife) and are no longer being developed or supported by the AppServ. 
We strongly recom;end that you install the latest production version available. 





If you install an older version of AppServ, it may contain security vulnerabilities that were patched or fixed in subsequent versions. 


If you have to install an older version, check if there are any security advisories that apply to the version. 


If you use Windows 9x, ME we consider you to use version below 2.0. 
If you use Windows NT,2000,2003,XP we consider you to use 2.4.x - 2.5.x. 


AppServ v 2.5.10 
Release Date : 2008-05-10 
Packages 

€ Apache 228 

© PHP 526 

© MySQL5051b E 


e phpMyAdmin 2.103 


Download : http//prdownloads.sourcefo 





AppServ v 2.6.0 








2.62 AppServ 官方 网 站 的 Version History 链接 
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© 从 导航 栏 上 的 “Howto Install" “Howto Use” 和 “FQA” 链 接 页 面 中 可 以 学 习 如 何 
安装 、 如 何 使 用 及 可 能 遇 到 的 问题 解答 。 

(2) 删除 本 地 计算 机 上 AppServ 以 前 的 版 本 。 

(3) 删除 本 地 计算 机 上 MySQL 以 前 的 版 本 。 

(4) 关闭 所 有 打开 的 程序 。 

(5) 临时 禁用 病毒 扫描 软件 和 防火 墙 。 


2.5. 安装 AppServ 






































下 载 的 AppServ-win32-8.0.0.exe 是 一 个 Windows 安装 程序 ， 即 一 个 可 执行 文件 。 
(1) 双击 下 载 的 “AppServ-win32-8.0.0”， 出 现 如 图 2.63 所 示 的 界面 。 
(2) 图 2.63 所 示 为 AppServ-win32-8.0.0 的 安装 向 导 界 面 ， 单 击 “Next” 按 钮 继续 。 


[E AppServ 800 Setup 





[epsevaoo Seu 


Welcome to the AppServ 8.0.0 
Setup Wizard 


Th wasrd mil gude you rough he nstalaton of Appi 
$25. 





essen 2.1 ebay 1999. 
Lay ism. ne softnore rorta 
Face, Sute 39, 


the frst releared verser of the Lester GPL It ao counts 
|a t sucesor of Pe GU Lbrary Pub cenae, verson 2 
Pe verson nmber 21] 


COMPUTE? == 


I you accept the terms of he sgreement, idk T Agree to continue. You must accept the 
ageerent retat Asper 8.0.0. 


iu 





























图 2.63 AppServ 的 安装 向 导 界面 Bl 2.64. AppServ 安装 许可 协议 界面 


(3) 图 2.64 所 示 为 AppServ-win32-2.5.10 安装 许可 协议 界面 , 阅读 使 用 条 件 和 条 款 , 单 
击 “I Agree” 按 钮 继续 。 


(4) 图 2.65 .中 要 求 选择 安装 的 目标 文件 夹 ， 改 变 为 D 盘 ， 单 击 “Next” 按 钮 继续 。 


[E AppServ ao0 Setup - [© AppServ &00 Setup 
Choose natall Location 


一 Select Componenta 
Choose the folder in which to instal AppServ 8.0.0. 1 


te, 
ou do not want to retl 





























图 2.65 AppServ 的 安装 目标 文件 夹 图 2.66 选择 安装 包 中 的 组 件 
(5) 图 2.66 里 要 求 选择 安装 包 中 的 组 件 ， 全 部 选中 ， 单 击 “Next” 按 钮 继续 。 
ÉN 注 ”如果 计算 机 上 没有 安装 需要 的 VC 文件 ， 将 出 现 图 2.67 所 示 的 提示 需要 安装 VC14 的 警示 框 ， 单 





击 “ 确 定 ”按钮 后 ， 会 进入 安装 向 导 界 面 ， 首 先 出 现 的 是 图 2.68 所 示 的 确认 条 款 和 条 件 的 对 话 


框 ， 选 中 复 选 框 后 ， 单 击 “ 确 定 ”按钮 ， 自 动 安装 ， 完 成 后 回 到 AppServ 的 安装 向 导 界 面 。 
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[58 Microsof Visual C+ + 2015 Redistributable 086) 14 — 


Microsoft Visual C++ 2015 
Redistributable (x86) - 14.0.23026 


全 AppServ 8.0.0 Setup 


Your system must install VC14 Runtime. 


Press OK to install it. 





图 2.67 提示 需要 安装 VC14 图 2.68 安装 VC14 对 话 框 


(6) 图 2.69 指出 Apache 的 设置 ， 要 求 输入 服务 器 的 名 称 和 管理 员 的 E-mail 地 址 ， 注 
意 HTTP 的 默认 端口 是 80, HTTPS 的 默认 端口 是 443， 单 击 “Next” 按 钮 继续 。 

(7) 图 2.70 是 要 求 对 MySQL 的 配置 ， 默 认 用 户 为 root， 输 入 密码 ， 默 认 字符 集 是 选择 
UTF-8 Unicode， 可 以 从 下 拉 列 表 中 选择 其 他 字符 集 ， 单 击 “Instali” 按钮 继续 。 





[E AppServ &00 Setup. [e AppServ &00 Setup. 


人 NU Nri swe commotion 
MSG | ero semsa ime reun, 


Beare enter Root seiswerd fr MYSQL Server 























图 2.69 设置 Apache 服务 器 2.70 配置 MySQL 服务 器 


(8) 图 2.71 表示 开始 安装 ， 就 是 把 相关 文件 释放 到 相应 的 文件 夹 中 。 
(9) 安装 完成 的 界面 如 图 2.72 所 示 ， 单 击 “Finish” 按 钮 完成 安装 。 





[E AppServ B00 Setup - [E AppServ 800 Setup = 
zi aa 
"wo Pesce vot vhi hep5ery 8.0.0 bere atale. Ce the AppServ 8.0.0 Setup 


oSer 8.0.0 has been natales on your computer 
Ck Frish to dose his wizard. 














swt hore 


回 sermsq 

















图 2.71 安装 进度 图 2.72 安装 完成 
(10) 图 2.73 一 图 2.76 是 AppServ 安装 文件 夹 里 的 文件 和 文件 夹 。 
QD 比较 图 2.73 所 示 的 Apache24 文件 夹 中 与 前 面 单独 安装 的 Apache24 文件 夹 中 的 内 
容 ， 发 现 有 所 不 同 ， 是 因为 版 本 不 一 样 。 配 置 文件 httpd.conf 也 在 conf 文件 夹 中 。 














~ 个 D > HER > BUDE(D) > AppServ > Apache24 > vO SED. P 
AppServ ^ 


bin proxy IJapache stop [E OPENSSL-README 
Apache24 conf 


9] ABOUT. APACHE B chances B README 
MysQL error 


php5 icons 


J INSTALL 
LICENSE 
NOTICE 
a modules — [SJapache start Ej OPENSSL-NEWS 


20 个 项 目 mee 1 个 项 目 


ne legs 





图 2.73 AppServ 件 夹 内 Apache24 文件 夹 内 的 文件 信息 


© 由 于 版 本 不 同 ， 图 2.74 所 示 的 MySQL 文件 夹 与 前 面 单独 安装 的 Apache24 文件 夹 
中 的 内 容 也 不 相同 。 配 置 文件 my.ini 在 MySQL 文件 夹 中 。 


- 个 > RAR > KIED) > AppServ > MySQL > 
AppServ g bin ]copYING 
Apache24 data 

MysQL docs 

php5 

php7 


~ 


11 个 项 目 。 选中 1 个 项 目 134 KB 





2.74 AppServ {ERA MySQL 文件 夹 内 的 文件 信息 


© 这 里 提供 了 两 个 版 本 的 PEE。 图 2.75 是 php5 文件 夹 。 配 置 文件 php.ini 在 php5 X 
件 炎 中 。 可 以 比较 一 下 两 个 版 本 文件 结构 的 差异 性 和 配置 文件 的 差异 性 。 


zm sE m 
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图 2.75 AppServ 件 夹 内 php5 文件 夹 内 的 文件 信息 


© 图 2.76 中 展示 的 www 文件 夹 是 AppServ 组 件 中 自 建 的 。 它 是 虚拟 站 点 的 根 目录 ， 
站 点 文件 放置 于 此 ， 通 过 http://127.0.0.1 EÈ http://www.localhost.com 可 以 访问 index.php. 
要 进入 phpMyAdmin， 只 需要 输入 http:/127.0.0.1/phpMyAdmin 。 





-个 

AppServ 
Apache24 
MysaQL 


Kon Dindexphp 
sim D) phpinfo.php 





2.76 AppServ FRA www 文件 夹 内 的 文件 信息 
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2.5.8 测试 AppServ 


(1) 在 浏览 器 地 址 栏 中 输入 http://127.0.0.1/, 可 进入 如 图 2.77 所 示 的 页 面 , 表 示 AppServ 
已 安装 成 功 。 





The AppServ Open Project - 8.0.0 for Windows 
Now you running on PHP 5.6.17. 





hn eee Vao ma 
PHP Information Version 


About AppServ Version 8.0.0 for Windows 
AppServ is a merging open source software installer package for Windows includes : 


+ Apache Web Server Version 24.18. 
* PHP Script Language Version 5.6.17 & 7.0.2 
* MySQL Database Version 5.7.10 


Database Manager Version 4.5.3.1 


Official Site : http://www.AppServNetwork.com 

Hosting by : http://www.AppServHosting.com. 

Change Language : Sii == 

tory way to bulia Webserver, Databae Serv wiih AppServ =) 
LX N 


图 2.77 www XRT index.php 页 面 


AN 这 里 ， 能 通过 链接 直接 进入 phpMyAdmin . PHP 信息 、 各 组 件 所 在 的 网 站 、AppServ 的 官方 网 
站 、 客 服 网 站 等 。 





(2) 在 如 图 2.77 所 示 的 页 面 中 单 击 PHP Information Version 5.2.6 链接 , 进入 如 图 2.78 
所 示 的 界面 ， 显 示 的 是 PHP 当前 的 版 本 信息 。 图 2.79 是 加 载 MySQL 模块 的 信息 。 





Windows NT ALFANG. PC 6.2 buld 9200 (Windows 8 Home Premium Editon) 1586 







































































Php. fie, lob data. Hp. fp. zip. compress zib, phar 
kep, vap 


eonverl icony ”mcyPL- mdectypt”, sting rot13, sting toupper, ting flower, sting stp. lags, convert", 
consumed. dechunk zi” 














图 2.78 测试 AppServ_PHP 版 本 信息 
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2.79 测试 AppServ_PHP 版 本 信息 [加载 MySQL 部 分 ) 
(3) 单 击 “phpMyAdmin Database Manager Version 4.5.3.1 ”链接 ， 进 入 类 似 图 2.56 所 示 
的 对 话 框 。 输 入 用 户 名 (roob， 以 及 安装 时 设置 的 密码 ， 单 击 “ 执 行 ”按钮 ， 进 入 如 图 2.57 
和 图 2.58 所 示 的 phpMyAdmin4.5.4.1 页 面 :一 





2.5.4 配置 Apache E 

事实 上 ， 作 为 有 经 验 的 工程 师 ， 在 开发 组 件 包 时 已 经 对 运行 环境 做 了 合理 的 配置 ， 不 
需要 改变 也 能 保障 正常 运行 。 这 里 重 温 配 置 文件 可 以 学 习 参数 配置 的 经 验 。 

(1) 在 Dreamweaver 中 打开 Apache24 的 Apache2 的 配置 文件 httpd.conf, 如 图 2.80 所 示 。 








# Directory) blocks below. 
a 


Directory /> 
Allowðverride none 
Require all denied 

</Directory> 


s p 


# 
# Note that fron this point forvard you must specifically allow 

# particular features to be enabled ~ so if something's not working as 
# you might expect, make sure that you have specifically enabled it 


$e 


[a] 
2 


locumentRoot: The directory out of which you will serve your 
documents. By default, all requests are taken from this directory, but 
syabolic links and aliases may be used to point to other locations. 


[E] 


# Possible values for the Options directive are "None", "All", 

# or any combination of. 

# Indexes Includes FollovSyaLinks SyaLinksifOwnerMatch ExecCGI MultiVievs 
# 

# Note that "MultiViews" must be named *explicitly* — "Options All^ 

# doesn't give it to you. 


«k FARAD 





Æ 2.80 # Dreamweaver 中 查看 httpd.conf 
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(2) 可 以 通过 菜单 命令 “编辑 | 查找 ”， 输 入 关键 字 来 快速 定位 ， 查 询 配置 参数 。 每 次 改 
变 配置 文件 并 保存 后 ， 必 须 在 Apache 重新 启动 后 才能 生效 。 





FINES 需要 确认 的 设置 如 表 2.2 所 示 。 注 意 到 Windows(DOS) 中 文件 路 径 的 “\"， 在 Apache 里 要 

















BOX "n. 
X22 配置 Apache 的 主要 参数 
主要 参数 行 参 数 值 
SSHNS 38 | Define SRVROOT "D:/AppServ/Apache24" 一 定义 变量 SRVROOT 
39 | ServerRoot "S{SRVROOT}" 一 通过 变量 SRVROOT 
妥 务 器 端口 60 | Listen 80 
加 载 PHP 5 模块 180 | LoadModule php5_module D:/AppServ/phpS/phpSapache2 4.dll 
添加 文件 类 型 184 | AddType application/x-httpd-php .php 
185 | AddType application/x-httpd-php-source .phps | —5.0 与 7.0 相同 
KJE PHP 配置 文件 目录 195 | PHPIniDir "D:/AppServ/php5/" 
指定 服务 器 名 称 237 | ServerName localhost:80. 
tog IE xt EL 261 | DocumentRoot "D:/AppServ/www" 
指定 主页 的 名 称 295 | DirectoryIndex index.html index.htm index.php 
KJE ScriptAlias 目录 378 | ScriptAlias /cgi-bin/ "$ {SRVROOT}/cgi-bin/" 





Jk 
Kanra 





2.5.5 ”修改 MySQE 服务 器 的 密码 


(1) 在 浏览 器 的 地 址 栏 中 输入 http://localhosuphpMyAdmin/, 首先 弹出 “链接 到 localhost" 


对 话 框 ， 要 求 输入 用 户 名 (root) 和 4 





码 (安装 时 设 定 的 )， 显 示 如 图 2.56 所 示 的 页 面 。 


(2) 输入 正确 的 用 户 名 和 密码 后 ， 显 示 如 图 2.57 和 图 2.58 所 示 的 页 面 。 


G) 单 击 “ 常 规 设置 ”区 域 下 的 “修改 密 三 








3” 链 接 ， 进 入 如 图 2.81 所 示 的 页 面 。 




















图 2.81 phpMyAdmin 中 修改 密码 为 无 密码 


Qe 动态 网 站 编程 环境 
o == SY 


(4) 可 以 单 击 “ 无 密码 ” 单 选 按钮 ， 或 者 在 密码 文本 框 中 输入 新 设置 的 密码 ， 单 让 
“执行 ”按钮 ， 回 到 图 2.82 所 示 的 页 面 。 可见 设置 密码 的 SQL 命令 和 更 新 配置 文件 
SR. 





Et 














em 





[eu e IDE 





SET password = " 





图 2.82 phpMyAdmin PREZZI | 


(5) 单 击 “ 用 户 账户 ”链接 ， 进 入 图 2.83 所 示 的 页 面 。 观 察 页 面 可 知 ， 当前 用 户 是 最 
后 一 行 的 root， 因 为 Host name 是 localhost， 与 页 面 上 方 的 一 致 。 





j mE Esa &ik5 - BPA^ - 95 S SA ^ E ) SH o Xu S TUE 由 3$ 


用 户 账户 概况 SS- 





区 
account allows a connection from any (&) host. 


RPA Hostname MB 全 局 权限 o mS Hf 

Dae % * Ngee 5 pnzon zs 
口 hos E ushee LEE] 
O rot 127001 . E. aL PRIVILEGES 是 y MERDA 5 P 
Db wot | mss Qaem jui 





[O mot loraion m anns i GEER jeu 
t (em em: eu 





LA 
a eme 
a 了 除 和 中 的 用 户 开户 


咏 锁 用 户 所 有 权限 , SSH, ) 
O 出 $ 与 用 户 同 各 的 数据 库 . 





图 2.83 phpMyAdmin 中 用 户 账户 页 面 


(6) 在 这 里 也 可 以 修改 密码 ， 单 击 所 在 行 的 图 标 碟 或 “修改 权限 ”链接 ， 进 入 编辑 权 
限界 面 ， 图 2.84 是 单 击 “ 修 改 密码 ”链接 后 的 页 面 。 
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Global BEE maea neee 


修改 权限 : 用 户 账户 root'@'localhost' 











^ 
SYM — 


图 2.84 phpMyAdmin 中 “修改 权限 ”的 “修改 密码 ”页 面 


2.5.6 ”添加 Windows 的 环境 变量 


同样 要 通过 “控制 面板 ”一 “系统 ”一 “高 级 系统 配置 % 在 “系统 属性 -高 级 ”对 话 框 
中 为 Apache 和 MySQL 设置 环境 变量 的 path 参数 ， 如 图 2.85 所 示 。 





96SystemRoot36\systern32 

%SystemRoot% 

SéSystemRood E System32QWbem 
SsSYSTEMROOTSA System 32 Windows PowerShell 1.0 
MI Ba Raa x 

、| DAappsen\php\ext 

|| DAappsenAmysqħbin 

DAwamp\php 


D:\wamp\php\ext 
D:\wamp\mysqbin 




















Æ 2.85 # Apache 和 MySQL 设置 环境 变量 的 path 参数 


o 
- V n T5 “动态 网 站 编程 环境 
O -一 | 


2.6 PHP 的 集成 开发 环境 


2.6.1 Dreamweaver 开发 工具 


从 MX 版 本 开始 ，Dreamweaver 开始 支持 PHP+MySQL 的 可 视 化 开发 。 因 为 几乎 不 写 一 
行 代码 就 可 以 建立 一 个 程序 ， 并 且 是 可 视 的 ， 学 习 静 态 网 页 设计 与 制作 时 大 多 数 都 会 选择 
Dreamweaver， 所 以 对 初学 者 来 说 是 比较 好 的 选择 ，Dreamweaver CS4 编码 器 界面 如 图 





比较 而 言 ，Dreamweaver 有 以 下 特点 。 
(1) 包含 了 语法 加 亮 、 函 数 补 全 、 形 参 提 示 等 特性 。 


(2) 但 4 








成 的 代码 比较 复杂 ， 安 全 性 也 一 般 。 


Q) 在 手写 程序 方面 ， 方 便 度 一 般 。 


(4) 在 调试 环境 方面 表现 得 也 不 够 理想 ， 不 适合 比较 复杂 的 编程 。 


Dy He or Ar X 














Dd - cx 
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[5] 4e [4 


jk FALD 





[body> (center? 


文件 中 Wo EEV XA W 格式 (0) 命令 (C VAD OW HHW 
php. TIUS 


标题: MAU BLOG - fywyj en wo CE 


E ($. SERVER[' REQUEST. METRON’ ]: == 'POST')[ 


if (!is -uploaded file(5 | FILES ["upfile"] [tmp 1 ssa 
echo “<font, colors'red' 文件 不 存在 ! font?" 
exit; 


j 
$file < $_FILES ["upfile"] : 
if($max file size < $file['size']) 1^% 
eché “<font color=’ red 文件 太 大 ! 
exit 
bU 
if (lin array ($file["type"]，$uptypes)) L// 检 查 文 件 甘于 
echo “<font color=’ red > 只 能 上 传 图 像 文件 或 Flash! </font>"; 
exit. 


if(lfile exists($destination folder)) 
nkdir($destination folder): 

$filename-$file['tmp name"] 

Simage size = getimagesize ($filename). 

Spinfo-pathinfo ($file['name"]): 

Sttype-pinto[extensicn]: 

Sdestination = $destination folder.time().".". $ftype: 

if(file exists($destination) && $overwrite !- true)[ 
echo “<font color=’ red 同名 文件 已 经 存在 了 ! 4a» 
exit. 

} 

证 (lmove_uploaded_file ($filename, $destination))[ 
echo “<font color=’ red 移动 文件 出 错 1 </a>" 


5 kK /1 秒 | 简体 中 文 (GB2312) 





v 








Æ 2.86 Dreamweaver CS4 编码 器 界面 


2.6.2 Eclipse 开发 工具 
Eclipse 是 IBM 旗下 的 一 款 开源 开发 工具 ， 可 以 使 用 插件 的 方式 实现 多 语言 的 开发 。 


Eclipse PDT 界面 如 








到 2.87 所 示 。 














2.86 
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Value 





E B Nee configuration [PHP Web Page] Array [0] 
Ea PHP Application Array [3] 
El o£ Remote Launch. (stepping) 


三 includes/register php [nain] : lineno 2 





recister rlo HI B reeister hl | database rhe | 





1 <?php 
2 require 'config.php'; 
3 require 'database.php'; 

fj 1 itype - f REQUEST[' type]; 

(d 5 sname = $ REQUEST['name']: 
6 $email = $ REQUEST['email']; 
5 


8 $db- mysqli connect($DB HOST, $DB USER, $DB PASSWORD, $DB-NAME); 
9 /* check connection */ TON ` 
10 if (!$db) ( 





图 2.87 Eclipse PDT 界面 

Eclipse PDT 是 一 套 开 发 工具 和 框架 ? ,可 以 提高 PHP 的 开发 效率 。 它 是 Eclipse 推出 的 
第 一 个 针对 PHP 开发 社区 的 项 目 ， 其 标准 基于 Eclipse Public License. Eclipse PDT 是 使 用 
Java 实现 的 一 套 插件 到 Eclipse 平台 的 汇 具 。 可 见 ， 它 具有 以 下 特点 : 

(1) 提供 上 下 文敏 感 的 编辑 器 。 

(2) 支持 语法 突出 … 代 码 辅助 和 代码 折 受 、 综 合 项 目 模型 。 

(3) 可 使 用 File. Project Outline Views 和 一 个 新 的 PHP Explorer View 来 检查 。 

(4) 支持 PHP 代码 的 增 量 调试 。 

(5) 允许 开发 人 员 和 独立 软件 商 轻松 扩展 PDT 来 创建 新 的 PHP 开发 工具 。 


263 ”其 他 开发 工具 

1. PHP Editor 

PHP Editor 是 仅 用 于 Windows 的 IDE. Xf PHP, CSS fll HTML 代码 提供 智能 支持 ,但 
不 对 JavaScript 的 代码 提供 智能 支持 。 

2. Zend Studio 


Zend Studio 运行 于 Windows、Mas OS X 和 Linux。 相 对 其 他 IDE，Zend Studio 是 最 好 
的 ， 它 提供 所 有 想 在 内 置 库 和 定制 代码 中 拥有 的 代码 智能 特性 ， 还 有 非常 好 的 调试 功能 ， 
并 且 容 易 设 置 。 把 代码 放 到 存储 库 中 ,会 连接 CVS 和 Subversion; 集成 的 FTP 能 把 代码 放 
到 服务 器 上 。 

3. 其 他 IDE 


PHP ED 只 限于 Windows，PHP Designer、Comodo 等 也 是 不 错 的 PHP 集成 工具 。 
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$ Da 章 总 结 


本 章 首先 介绍 了 与 动态 网 站 编程 环境 相关 的 构成 要 素 ， 接 着 详细 介绍 了 Windows 操作 
系统 下 的 Apache、PHP、MySQL、phpMyAdmin 及 AppServ 的 安装 过 程 ， 最 后 简要 介绍 了 
PHP 的 集成 编程 环境 。 


e 思考 练习 
(1) 与 动态 网 站 编程 环境 相关 的 要 素 有 哪些 ? 
(2) 安装 软件 前 需要 做 哪些 准备 工作 ? 


CSAT 


项 目 2-1 安装 和 配置 编程 环境 

项 目 目标 : NN 
(1) 安装 Apache, PHP. MySQL fil PDMSAdnin, 
(2) 修改 相关 配置 文件 。 

FR: - E 
(1) 根据 本 章 案例 指导 ， 安 装 Apache, PHP, MySQL fil phpMyAdmin. 
(2) 根据 本 章 案例 指导 ， 修 改 相关 配 置 文件 。 | 

(3) 在 phpMyAdmin 上 修改 MySQL 的 权限 为 无 密码 。 





项 目 2-2 安装 和 配置 编程 环境 Eclipse PDT 
项 目 目 标 : 
(1) 了 解 编程 环境 Eclipse PDT 的 优 缺 点 。 
(2) 通过 网 络 学 习 搭建 PHP 编程 环境 的 方法 。 
pa n 
(1) 利用 百度 、 谷 歌 等 搜索 工具 了 解 Eclipse PDT 的 搭建 方法 。 
(2) 搜索 相关 论坛 ， 了 解 Eclipse PDT 的 搭建 方法 。 
(3) 选择 一 种 Eclipse PDT 的 搭建 方法 ,按照 指导 步骤 安装 和 配置 编程 环境 Eclipse PDT. 





网 站 主页 设计 与 PHP 基础 


通过 本 章 的 学 习 ， 能 够 使 读者 : 
(1) 知道 动态 网 站 主页 的 设计 方法 。 
(2) 明确 制作 网 页 的 基本 技术 。 

(3) 掌握 PHP 的 基本 语法 

(4) 了 解 动态 网 站 的 链接 策略 。 


LEE 


本 章 为 读者 准备 了 以 下 学 习 资 源 : 

(1) 示范 案例 :- 展示 “网 上 书店 ”主页 的 设计 与 实现 过 程 ， 对 应 本 章 的 3.1~3.3 节 。 案 
例 代码 存放 在 文件 炎 “ 教 学 资源 \wuyavch3” 中 。 

(2) 技术 要 点 :描述 “PHP 语言 基础 ”， 对 应 本 章 的 3.4 节 。 其 中 的 示例 给 出 了 相关 技 
术 的 说 明 实例 ， 代 码 存放 在 文件 夹 “ 教 学 资源 \extend\ch3\”。 

(3) RERA: 代码 存放 在 文件 夹 “ 教 学 资源 \exercise\ch3\” 中 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 : 

(1) 解读 示范 案例 的 分 析 和 设计 。 

(2) 模仿 练习 : 选择 一 个 PHP 集成 开发 工具 ， 如 Dreamweaver， 按 照 实现 步骤 重 现 
案例 。 

(3) 扩展 练习 : 按 实践 项 目的 要 求 ， 先 明确 项 目 目标 ， 再 在 PHP 集成 开发 环境 中 实现 
项 目 代 码 ， 接 着 对 代码 中 的 PHP 语言 要 素 进行 分 析 ， 提 升 理 解 和 应 用 能 力 。 

学 习 过 程 中 ， 提 倡 结对 或 3 人 组 成 学 习 小 组 ， 一 起 探讨 和 研究 主页 的 设计 ， 但 对 PHP 
语言 基础 的 学 习 和 具体 项 目的 实现 还 是 鼓励 能 独立 完成 。 
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本 章 案例 为 设计 和 实现 网 上 书店 的 主页 ， 涉 及 XHTML、CSS 等 网 页 制作 的 基本 技术 。 
从 案例 中 能 体会 网 站 上 主页 的 作用 和 设计 方法 ， 并 初步 认识 PHP 语言 的 基础 知识 。 








3.1 网 站 主页 的 设计 


3.1.1 主页 中 的 页 面 元 素 





根据 第 1 章 中 对 网 站 的 整体 规划 ， 主页 应 该 包含 以 下 页 面 元 素 ; 


(1) 网 站 的 LOGO。 

(2) 网 站 的 Banner。 

(3). 网 站 的 导航 条 。 

(4) 网 站 的 查询 栏目 。 

(5) 网 站 的 特色 栏目 。 

(6) 常见 问题 解答 链接 。 

(7) 联系 我 们 的 方式 。 

(8) 网 站 版 权 和 工商 备案 信息 。 
(9) 顾客 访问 网 站 的 计数 器 。 


342 规划 主页 的 结构 
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根据 对 网 站 主页 所 包含 页 面 元 素 的 描述 ， 可 得 如 图 3.1 所 示 的 主页 结构 。 
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Bl 3.1 


搜索 和 分 类 
右 侧 证 要 内 容 main.php 


浮动 框架 
SUP 


“3 








底部 版 权 信 息 bottom.html 





网 站 主页 的 结构 
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3.1.8. 布局 页 面 版 式 

















(1) 主页 index.php RH T 型 布局 ， 规 划 如 下 所 示 。 其 中 的 样式 定义 在 index.css 中 。 











H 








top.php: 780x90 





leftphp: 180x380 main.php: 600x380 





linkbottom.html: 780x160 





(2) 头 部 top.php 的 页 面 规划 如 下 所 示 。 其 中 的 样式 定义 在 top.ess 中 。 





Logo: 180x50 Banner: 600x50 








: 780x20 








: 780x5 


导航 栏 2，780x20( 背 景色 浅 橘 黄 帮 FEFGE) 









4399), dn 集 、 单 行文 本 、 下 拉 列 表 、 按 钮 
查询 : 180x*( 文 本 : #399, 背景 色 : #FFCC99, 链接 : link#099, visited r#999, hove#C30, active#F96) 

友情 链接 : 180x40( 文 本 : #399, 7 #FFCC99)， 表 单 、 下 拉 列 表 

空白 ，180x25( 背 景色 : #399) 





















































(4) 布 侧 内 容 main.php 的 页 面 规划 如 下 所 示 。 甚 中 的 样式 定义 在 main.css 中 。 
580x30 更 多 ……( 超 链接 ) 卖 栏目 ， (文本: WFFCC99, 7 
图 书 图 片 ，85%55，、 图书 说 明 : 190x55， 图 书 图 片 : 85x55， 图 书 说 明 190x55 

( 超 链接 ) ( 超 链 接 ) ( 超 链接 ) ( 超 链接 ) 
580x30 更 多 ……( 超 链接 ) 特价 栏 (文本 : WFFCC99, PRÉE: #399) 
图 书 图 片 ，85x55， 图 书 说 明 : 190x55, 图 书 图 片 ，85x55， 图 书 说 明 190x55 

( 超 链 接 ) ( 超 链接 ) ( 超 链 接 ) ( 超 链接 ) 
580x30 更 多 ……( 超 链接 ) 推荐 栏目 ， (文本: #FFCC99， 背 景色 : 4399) 
图 书 图 片 ，85x55， ”图书 说 明 : 190x60, ERJ: 85x55, 图 书 说 明 190x60 

( 超 链接 ) ( 超 链 接 ) ( 超 链接 ) ( 超 链接 ) 

(5) 底部 linkbottom.php 的 页 面 规划 如 下 所 示 。 其 中 的 样式 定义 在 bottom.css 中 。 
计数 器 : 220x100 购买 图 书 付款 方式 的 订单 退货 条 款 联系 我 们 
(背景 色 : 399) 88x18( 背 景色 : 4399) 118x18( 同 右 ) ”172x18( 同 右 ) 





链接 项 目 : link#399, visited 4906, hove &F90, active 4099 J H 
公共 模块 : bottom.php: 180x60 
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(6) 底部 版 权 信息 bottom.php 的 页 面 规 划 如 下 所 示 。 
版 权 信息 行 ，( 文 本: 默认 ， 大 小 : 14px， 行 间距 :150%) 
工商 备案 行 (同上 ) 
浏览 建议 行 (同上 ) 














FN 作为 一 个 公共 模块 的 bottom.php 页 ， 可 用 于 留言 板 、 聊 天 室 、 登 录 与 注册 等 网 页 。 


nu 


3.44 用 Fireworks 创建 网 页 模型 


1， 准 备 网 站 素材 

主页 中 需要 5 幅 图 像素 材 和 一 个 动画 素材 。 其 中 ，logo:gifs lefibg.jpg. hotitem.jpg. 
saleiten.jpg 和 remitem.jpg 在 Fireworks 中 绘制 ，bannerigif 在 Ulead GIF Animator 中 制作 。 
图 像 文件 ，logo.gif 的 绘制 过 程 ， 效 果 如 图 3.2 所 示 。 

WuYabool rr 

图 3.2 网 站 的 logo 
(1) 启动 Fireworks，“ 新 建文 档 ” 对 话 框 如 图 3.3 所 示 。 


Bras 
Wmw[w 7] x 
ame[s je 

BER. [2 ] xxt 


ase 

es 

Oi 

O&sx(: 
mm 

















图 3.3 “新 建文 档 ” 对 话 框 
的 属性 如 图 3.4 所 示 。( 线 颜色 : #FF9900. ) 
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(2) ha 
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图 3.4 ”绘制 椭圆 的 属性 
内 输入 文字 “无 涯 ”的 属性 如 图 3.5 所 示 。( 文 本 颜色 : #339999， 线 颜色 : 

















= 





(3) ER 
#FFCC99. ) 
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回 自动 员 整 字 距 
图 3.5 输入 文字 “无 涯 ”的 属性 
(4) 在 椭圆 右上 角 处 输入 文字 “WuYabook.com” 的 属性 如 图 3.6 所 示 。( 文 本 颜色 
#FF9900. ) 





[o 
图 3.6 输入 文字 “WuYabook.com” 的 属性 


会 制 线条 的 属性 如 图 3.7 所 示 。( 线 颜色 : SFFCCO9. ) 








(5) aci i 中 央 绘 


Li 67x Ue Missan Bho |v 正常 
XR: ARES 0 


jb |o dvi ge e 
a[i ] x [5 DNA o ow p H 
Ea) v ] sem 








图 3.7… 绘 制 线 条 的 属性 


(6) 在 椭圆 右 下 角 处 输入 文字 “网 上 书店 ”的 属性 如 图 -3.8 所 示 。 (文本 颜色 : 4339999, ) 


xk RES 
“EP liavo 


v 3 [w 
m» | x [BW 


] ~ elo 
E [os 





"m | ep ]vi es 


图 3.8 输入 文字 “网 上 书店 ”的 属性 
(7) 执行 菜单 命令 “文件 ”一 “另存 为 ”， 把 文件 保存 为 logo.gif。 


leftbg.jpg 等 其 他 图 像 的 制作 过 程 类 似 于 logo.gif。 效 果 与 属性 如 图 3.9 所 示 。 
ALLILEN 


lefibg.ipg 
大 小 : 176X376; 
X. 图 书 查 询 、 字 体 (华文 行 楷 )、 
上 方 区 域 : 圆 角 和 矩形 (190X 48)、 
中 间 区 域 ， 5875(176x320). 4 


大 小 (20)、 颜 色 (#FFCB99); 
位 置 (0，0)、 填 充 色 (#339999); 





(0，29)、 填 充 色 (#FFCB99); 
g— 下 方 区 域 ， 贺 角 和 矩形 (190X48)、 位 置 (0，329)、 填 充 色 (#339999); 
(a) 效果 (b) 属性 
A£ks hotitem.jpg. saleiten.jpg 和 remItem.jpg. 
"TP 大 小 : 176X376、 背 景色 (#FFCB99); 
Yr. 字体 (华文 行 : -小 颜 
mm ^7 体 (华文 行 楷 )、 大 小 (20)、 颜色 (#339999)。 
(c) 效果 (d) 属性 
图 3.9 


leftbg.jpg 及 其 他 图 像 的 效果 与 属性 





第 3 章 ”网 站 主页 设计 与 PHP 基础 


图 像 文 件 ，banner.jpg 的 绘制 过 程 ， 效 果 如 图 3.10 所 示 。 


(1) 启动 Fireworks CS3, 新 建文 档 。 绘制 如 图 3.10 所 示 的 图 像 ， 并 以 文件 名 banner.jpg 
保存 在 image Fo 


填充 色 (#FFEFCE) 
图 3.10 banner.jpg 的 效果 


(2) 启动 Ulead GIF Animator 后 ， 进 入 如 图 3.11 所 示 的 “启动 向 导 ” 对 话 框 ， 单 击 “ 空 
和 动画 ”前 的 按钮 六 ， 进 入 应 用 程序 窗口 。 

G) 单 击 标准 工具 栏 上 的 “新 建 ”按钮 日 ， 弹 出 如 图 3.12 所 示 的 “新 建 ” 对 话 框 ， 设 
置 “ 画 布 尺寸 ”为 600x50px，“ 画 布 外 观 ” 设 为 “完全 透明 ”。 


























aes 
BEI om RD. 打开 
p mas [B ons meme 








gi son Bo mee 


Quos Bg ome 


厂 下 一 次 不 办 未 这 个 对 活检 [xa | 





图 3.11 “启动 动画 ”对 话 杠 图 3.12 “新 建 ”对 话 框 


(4) 选择 菜单 “文件 一 “添加 图 像 ”命令 ”从 弹出 的 “打开 图 像 文 件 ”对 话 框 中 选 
择 在 (D) 中 绘制 并 保存 的 文件 banner.jpg。 

(5) 单 击 帧 面板 上 的 第 1 帧 画面 以 选中 它 ， 再 单 击 下 方 的 “相同 ”按钮 局， 复制 第 2 
帧 画面 ， 如 图 3.13 所 示 。 

(6) 单 击 工具 面板 上 的 开 | 按 钮 ， 单 击 工作 区 左上 角 ， 弹 出 “文本 条 目 框 ” 对 话 框 ， 如 
图 3.14 所 示 ， 输 入 文字 “书籍 是 人 类 进步 的 阶梯 ”， 单 击 色 块 弹出 快捷 菜单 ， 选 择 “Ulead 
颜色 选择 器 ”命令 ， 出 现 如 图 3.15 所 示 的 “Ulead Color Picker” 对 话 框 ， 选 择 橘红 色 (R: 
255,G: 148,B: 40). 


文本 科目 本 x 


= ERE + 27 
原本 : [Caizsz_5B2312 - 
anzurv Esa pe 


SRAAX&suMa |; TE 
rm H = 
oig + e 


Pal zz »»|B gx F esn 











图 3.13 复制 帧 图 3.14 “文本 条 目 框 ”对 话 框 


PHP 动 态 网 页 设计 与 制作 案例 教程 第 = 版 ) 一】 

















(7 在 “字体 ” 属性 面板 上 设置 字体 为 “华文 行 楷 ”， 大 小 为 32， 如 图 3.16 所 示 。 
(8) "Tak RS 下 脚 的 下 拉 箭 头 ， 在 弹出 的 快捷 菜单 中 选择 “阴影 ”命令 ， 弹 出 “阴影 ” 
对 话 框 ， 勾 选 “ 阴 影 ” 复 选 框 ， 按 如 图 3.17 所 示 设 置 参数 。 


Ulead Color Picker 
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图 3.15 Ulead Color Picker 对 话 框 图 3.17 “阴影 ”对 话 框 
(9) 确定 选中 了 输入 的 文字 对 象 ,~ 右 击 ,- 从 快捷 菜单 中 选择 “文字 ”一 “ 需 虹 ”命令 ， 
弹出 “ 震 虹 设置 ”对 话 框 ， 勾 选 “ 井 虹 ” 复 选 框 ， 按 如 图 3:18 所 示 设 置 参数 。 单 击 色 块 ， 
弹出 如 图 3.15 所 示 的 对 话 框 > 选择 浅黄 色 (R: 255,G: 221,B: 120). 
(10) 从 菜单 栏 中 选择 上 对象 ”一 “对 象 属性 ”命令 ,弹出 “对 象 属性 ”对 话 框 ， 按 如 
图 3.19 所 示 设 置 参 数 。 





oeside 
rama (1...99) ram 
— 








图 3.18 “ 需 虹 设置 ”对 话 框 图 3.19 “对 象 属性 ”对 话 框 


(11) 选择 菜单 “对 象 ”一 “文本 ”一 “ 拆 分 文本 ”命令 ， 可 见 每 一 个 文字 形成 独立 对 
象 ， 如 图 3.20 所 示 。 








图 3.20” 拆 分 文本 对 象 效果 图 


(12) fid 








f 帧 面板 下 方 的 “相同 ”按钮 名 9 次 ， 复 制 出 9 帧 画面 ， 此 时 


1 帧 只 含有 背景 图 像 ， 后 面 10 帧 还 含有 文字 。 





(13) 选 


PAS 2 帧 ， 在 对 象 管 
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的 蒿 图 标 ， 隐 藏 它们 ， 使 背景 图 和 文字 “ 书 ” 处 于 显示 状态 ， 如 图 3.21 所 示 。 
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图 3.21 设置 拆 分 文本 对 象 的 显示 





HE 11 帧 画面 ， 第 


理 器 面板 上 ， 单 击 除 背 景 图 和 文字 “ 书 ”以 外 的 9 个 层 上 


(14) 选中 第 3 帧 ， 在 对 象 管理 器 面板 上 ， 设 置 背景 图 及 “ 书 ”“ 籍 ”两 字 为 显示 状态 ， 
隐藏 其 余 的 字 。 

(15) 依 此 类 推 ， 分 别 设置 第 4 一 11 帧 ， 让 文字 依次 显示 出 来 。 

(16) 单 击 帧 面板 中 的 播放” 按钮 >|， 观 察 动 画 效果 ， 发 现 动 画 速度 偏 快 。 


(17) 在 帧 
在 空白 处 右 击 ， 


图 3.22 所 示 ， 


设置 “延迟 ” 值 为 30。 


面板 中 选中 第 1 帧 ， 按 住 Shif&t 键 ;再 选中 最 后 一 帧 ， 使 所 有 的 帧 都 被 选中 。 
在 快捷 菜单 中 选择 “画面 帧 属性 ”命令 ， 弹 出 “画面 帧 属性 ”对 话 框 ， 如 


(18) 选择 菜单 “文件 ”一 “另存 为 ”一 “GIF 命令 ”， 或 单 击 标准 工具 栏 上 的 “保存 ” 


Ta eti oit) 1 


为 ”对 话 框 ， 


图 3.22 “画面 帧 属性 ”对 话 框 


以 banner.gif 为 文件 名 保存 文件 。 


保存 为 UFO 文件 
Bot i (1/100 4) 保存 为 PSD 文件 - 


z% 保存 为 图 象 画 面 
i 全 为 视频 文件 
保存 为 Macromedia Flash (SWF) 文件 ^ 








2. 创建 主页 模型 








根据 前 





























等 人 员 交 流 ， 


如 图 3.24 所 示 。 














下 拉 列 表 ， 如 图 3.23 所 示 ， 从 中 选择 “保存 为 GIF 文件 ”命令 ， 弹 出 “另存 


图 3.23 标准 工具 栏 上 的 “保存 ”下 拉 列 表 


1 对 主页 的 设计 , 使 用 Fireworks 绘制 主页 的 模型 ,以 便 对 设计 修改 和 与 制作 者 


W 








图 324 主页 效果 图 NAT 


3.2 mess 


3.2.1. 在 Dreamweaver 中 创建 网 站 … 

(1) 启动 Dreamweaver， 新 建 PHP xe. Y XN 

(2) 执行 菜单 命令 “站 点 ” 一 “新 建站 点 ”， 弹出 “waya 的 站 点 定义 为 ”对 话 框 ， 按 
图 3.25 所 示 设 置 “ 本 地 信息 ” 选项 参数 值 。 "X 





masno: S] 
FORRIN: e 
Brace D 已 
MRF: OMM OASRARG) 
acr 地 址 00: (http 7 
ENSE C eR Ac Ent D 
"is ERR C 








3.25 “wuya 的 站 点 定义 为 ”对 话 框 


(3) Æ “wuya 的 站 点 定义 为 ”对 话 框 中 ， 按 如 图 326 所 示 设 置 “ 测 试 服务 器 ”选项 参 
数值 。 
(4) 单 击 “确定 ”按钮 。 选 择 右 侧 的 “文件 ”面板 ， 可 见 新 建 的 站 点 。 


Q, 
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(5) 在 “文件 ”面板 中 ， 按 照 1.3 节 中 规划 的 网 站 目录 结构 ， 创 建 网 站 的 目录 结构 ， 如 


图 3.27 所 示 。 
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图 3.26 设置 “测试 服务 器 ”选项 参数 值 
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327 ”主页 效果 图 


单 击 选中 站 点 根 目录 ， 从 右 击 快捷 菜单 中 选 坚 “新 建文 件 夫 ” 命 令 ， 新 建 默认 名 为 “untitled” 的 文件 


夹 ， 输 入 新 文件 夹 名 ， 就 在 站 点 根 目 隶 下 创建 了 一 个 新 目录 . 


(6) 把 3.1.2 节 中 绘制 的 图 像 文 件 和 动画 文件 复制 到 jimages 目录 下 。 


z CSSR E 


3.22 布局 页 面 元 素 的 样式 


代码 文件 :index.css 
(1) 启动 Dreamweaver， 新 建 CSS 文档 。 


(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


Gcharset "utf-8"; 

/* CSS Document */ 

.ind Pdl (  /* 定 义 左边 区 域 */ 
float: left; 
width: 180px; 

) 

.ind #d2 (  /* 定 义 右边 区 域 */ 
margin-top: 0; 
margin-right: 0; 
margin-bottom: 0; 
margin-left: 180px; 
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.clear ( /* 清 除 左 右 布局 */ 
clear: both; 
height:0; 


.ind #container (  /* 定 义 页 面容 器 */ 
width:780px; 
margin:0 auto; 
padding:0; 
) 
body (  /*383 


margin: 0px; 





定义 页 面 主体 的 内 外 补丁 */ 


padding: Opx; 





(3) 把 文档 以 index.css 为 文件 名 保存 在 CSS 文件 夹 下 


代码 文件 : top.css 





CSS 文档 。 
， 切 换 到 “代码 ”视图 输入 如 下 代码 


(1) 在 Dreamweaver 中 ， 新 建 
Q) 单 击 “ 代 码 ” 书 


Gcharset "utf-8"; 
/* CSS Document */ 
body ( 

font-family: "Ae"; 





font-size: l4px; 
) 
#top ( /* 定 义 项 部 区 域 */ 
height: 95px; 
width: 780px; 
padding-top: 0px; 
padding-right: 20px; 





padding-left: 0px; 
padding-bottom: 0px; 

} 

vail { /* 定 义 导航 栏 1 */ 
padding-top: 6px; 
padding-right: 20px; 
padding-bottom: 6px; 

} 

#vai2 { /* 定 义 导航 栏 2 */ 
background-color: #FFEFCE; 
padding-right: 20px; 
padding-bottom: 6px; 

) 

a:link ( /* 定 义 包含 超 链接 的 文 
color: #399; 
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:active { /* 定 义 超 链接 被 激活 的 文字 颜色 */ 
color: #399; 


m 


a:visited | /* 定 义 超 链接 被 访问 过 的 文字 颜色 */ 
color: #D6D6D6; 


a:hover ( /* 定 义 超 链接 被 指向 的 文字 颜色 */ 
color: #F93; 





(3) 把 文档 以 top.css 为 文件 名 保存 在 CSS 文件 夹 下 
代码 文件 :left.css 

(1) 在 Dreamweaver 中 ， 新 建 CSS 文档 

(2) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


Gcharset "utf-8"; 
/* CSS Document */ 
Kleftbg( — /* 定义 左 侧 容器 */ 
background-image: url(../images/leftbg.jpg); 









background-repeat: no-repeat; 
width:180px; 

height:380px; 

background-position: center center; 

) 

nume { /* 定义 图 书 搜索 区 域 */ 
padding-top: 30px; 
margin-bottom: 4px; 

} 

*sele { /* 定义 下 拉 列 表 */ 
margin-left: 4px; 
margin-bottom: 4px; 

} 

#f1 {  /* 定义 分 类 查询 和 友情 链接 */ 
padding-top: 4px; 
margin-bottom: 4px; 

} 

.bt{ /* 定义 标题 */ 
font-family: "RA"; 
font-size: 14px; 
font-weight: bold; 
color: #399; 

} 

txt { /* 定义 输入 文本 框 中 的 文字 */ 
font-family: "Ak"; 


font-size: l4px; 
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.text { /* 定义 输入 文本 框 中 的 默认 文字 */ 
font-family: "R"; 

font-size: 14px; 

color: #999; 

font-style: italic; 

} 
fieldset( /* 重新 定义 fieldset 标记 */ 

width: 165px; 

border: lpx solid #399; 

margin-right: 6px; 

margin-left: 6px; 

padding-top: 2px; 

padding-right: 0px; 

padding-bottom: 2px; 

padding-left: 0px; 

} 

:link (color: #099; text-decoration: none; } 
¿visited (color: #999; text-decoration: none; } 


a 
a 
a:hover { color: #C30; text-decoration: none; } 
a:active (color: #F96; text-decoration: none; } 
a 





{ font-size: l2px;)  /* $8 
form (  /* jog X form 标记 */ 


margin: 4px; 


定义 a 标记 */ 





padding: 0px; 





(3) 把 文档 以 left.css 为 文件 名 保存 在 CSS 文件 夹 下 





代码 文件 : main.ess 


(1) {E Dreamweaver 中 ， 新 建 CSS 文档 

(2) 单 击 “ 代 码 ” 书 切换 到 “代码 ”视图 ， 输 入 如 下 代码 
écharset "utf-8"; 

/* CSS Document */ 


body ( 
font-family: "宋体 "; 





font-size: 14px; 
} 
#rightbt1{ /* 定义 热卖 标题 */ 
background-image: url(../images/righttitle.jpg); 





background-repeat: no-repeat; 
width:580px; 

height:30px; 

background-position: right bottom; 
padding-top: 2px; 

padding-right: 20px; 
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$rightbt2( — /* 定义 特价 标题 */ 
background-image: url(../images/righttitle2.jpg); 
background-repeat: no-repeat; 
width:580px; 
height:30px; 
background-position: right bottom; 
padding-top: 2px; 
padding-right: 20px; 


frightbt3( /* 定义 推荐 标题 */ 
background-image: url(../images/righttitle3.jpg); 
background-repeat: no-repeat; 
width:580px; 
height:30px; 
background-position: right bottom; 
padding-top: 2px; 
padding-right: 20px; 





*frightconnect ( — /* 定义 内 容 容器 */ 
height: 90px; 
width: 580px; 
padding-top: 5px; 
padding-right: 20px; 
padding-left: 20px; 
padding-bottom: 2px; 

) 

#imgc ( — /* 定义 图 书 缩 略 图 区 域 */ 
height: 55px; 
width: 55px; 
padding: 2px; 
margin: 2px; 


:link (color: $399; text-decoration: none;) 


) 

a 

a:visited (color: 4999; text-decoration: none;} 

a:hover (color: #F90; text-decoration: underline;) 

a:active {color: #0CC; text-decoration: none; } 

table,tr,td (  /* 重新 定义 table,tr,td 标 记 */ 
margin: 0px; 


padding: Opx; 





(3) 把 文档 以 main.css 为 文件 名 保存 在 CSS 文件 夹 下 
代码 文件 ，bottom.css 


(1) 在 Dreamweaver 中 ， 新 建 CSS 文档 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代 在 
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Gcharset "utf-8"; 

/* CSS Document */ 

body ( 
font-family: "宋体 "; 
font-size: 14px; 
margin: 0px; 
padding: Opx; 

} 

#bottom {  /* 定义 底部 容 
height: 180px; 
padding-top: 2px; 

} 

#timersFrame ( /* 定义 计数 
padding-right: 2px; 


i sy 








padding-bottom: lpx; 

} 

#copyright (  /* 定 义 版 权 信 息 */ 
padding-top: 2px; 
height: 60px; 
text-align: center; 
font-size: 14px; 
line-height: 15 

) 

li(  /* 重 新 定义 li 标记 */ 
padding: Opx; 
list-style-position: inside; 





list-style-type: disc; 
margin-top: 2px; 
) 
ul { /* 重 新 定义 ul 标记 */ 
padding: Opx; 
margin-left: 2px; 
list-style-position: inside; 
font-size: 12px; 


slink [colors 43997] 

:visited (color: $906;] 
:hover ( color: #F90;} 
:active ( color: #099;} 


(3) 把 文档 以 bottom.css 为 文件 名 保存 在 CSS 文件 夹 下 


py py 





^ PHPá E 
3.23 ”实现 主页 的 结构 
代码 文件 : index.php 


o 
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(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

D 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http: //www.w3.org/TR/xhtmll1/DTD/xhtmll-transitional.dtd"» 


<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 





<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 

<title> 无 涯 网 上 书店 </title> 

<link href="css/index.css" rel="stylesheet" type="text/css" /> 
</head> 
<body class 





<div id="container"> 

<div><iframe name-"topFrame" id-"topFrame" scrolling-"no" 
height-"95" width-"780" src-"top.php" marginwidth-"0" marginheight-"0" 
border-"0" frameborder-"0" align="center"> 不 支持 </iframe></div> 

«div id-"dl"» 

«iframe name-"leftFrame" id-"leftFrame" scrolling-"no" 
heightz"380" width-"180"src-"left.php" marginwidth-z"0" marginheight-"0" 
border-"0" frameborder-"0" align="center"> 不 支持 </iframe> 

</div> 
<div id="d2"> 
«iframe nam 





mainFrame" id 





mainFrame" scrolling="no" height-"380" 
width-"600"src-"main.php" marginwidth-"0" marginheight-"0" border-"0" 
frameborder-"0" align="right"> 不 支持 </iframe> 

</div> 





<span class="clear" ></span> 
<div> <hr/> 
<iframe name="bottonFrame" id="bottonFrame" scrolling="no" height= 
"160" width="780" src-"linkbottom.html" marginwidth="0" marginheight-"0" 
border-"0" frameborder-"0" align="center" > 不 支持 </iframe> 
</div> 
</div> 
</body> 
</html> 


(3) 把 文档 以 index.php 为 文件 名 保存 在 ; 
3.24 ”编辑 主页 的 栏目 内 容 








点 根 文件 夹 下 。 


代码 文件 : top.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 


"http://www.w3.org/TR/xhtml1/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 





wb 一 
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<head> 
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 
<title> 无 涯 网 上 书店 </title> 
<link href="css/top.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
«div id="top"><img src-"images/logo.gif" width-"180" height="50" 
/><img src-"images/banner.gif" width-"600" height-"50" /> 
«div id-"vail" align-"right"» 
<a href="#" target- " blank" > 登录 </a>&nbsp;|&nbsp; 
> 查看 购物 车 </a>&nbsp; | bsp; 
«a href="#" target="mainFrame"> 清 空 购物 车 </a> &nbsp; | &nbsp; 
«a href="#" target="mainFrame"> 订 单 查询 </a>&nbsp; | &nbsp; 








«a href target- "mainFram 


«a href="#" target-" blank"> 会 员 管理 </a>&nbsp; | &nbsp; 
blank"> 聊 天 室 </a>&nbsp; | &nbsp; 
客 留言 </a> 





<a href: 
<a href="#" target=" blank"> 顾 
</div> 

<div id="va align="center"><a href="#"> 热 卖 图 书 
«/a»&nbsp; |&nbsp;«a href="#"> 特 价 图 书 </a>&nbsp; |&nbsp;<a href="#"> 推 荐 图 
B«/a»&nbsp;|&nbsp;«a href="#"> 最 新 图 书 </a></div> 








</div> 
</body> 
</html> 





(3) 把 文档 以 top.php 为 文件 名 保存 在 站 点 根 文件 夹 下 
代码 文件 : left.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 : 
(2) 单 击 装 代码” 标签， 切换 到 “代码 ”视图 ， 输 入 如 下 代码 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<title> 搜 索 图 书 </title> 


<link href="css/left.css" rel="stylesheet" type="text/css" /> 





<script type="text/javascript"> 
function ck frml()í 
var err=""; 
var oj-window.frml.input; 
if (oj.value--"")( 
err=" 输 入 不 能 为 空 !"; 
window.alert (err); 








oj.focus(); 


0j.value- 
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} 
</script> 
</head> 
<body> 
<div id=" 
<div id="nume"> 
<form name="frml" method="post" action="serach key.php"> 
<fieldset><legend class="bt"> 图 书 搜索 </legend> 
<input name="keys" id="sele" clas text" type="text" value="* 请 输 
A" size-"18" maxlength-"20" onClick="this.value='';"/><br/> 





eftbg" align-"left"» 





«select id-"sele" name-"seltl" > 
«option value-"book name"> 书 名 </option> 
<option value="author"> 作 者 </option> 
<option value="pub_date"> 出 版 日 期 </option> 
<option value="publisher"> 出 版 社 </option></select> 
<input type="button" name-"button" value=" 查 询 ” onmousedown= 
"ck frml();"/» 
«/fieldset» 
«/form» 
«/div» 
«div id="f1"> 
«form» 
«fieldset»«legend class="bt"> 分 类 查询 </1egend> 
«iframe name-"numeFrame" allowtransparency 
width-"165" src= "left nemu.php" marginwidth-"0" marginheight-"0" border-"0" 
frameborder="0"> 不 支持 </iframe> 
</fieldset> 
</form> 
</div> 
«div id="f1"> 
<form> 
<fieldset><legend class="bt"> 友 情 链 接 </legend> 
<select id-"sele" name-"selt2" onchange-"javascript:window.open 











"true" scrolling-"no" 





(selt2.value);" > 
«option value-"http://www.dangdang. com"»&nbsp; &nbsp; 当当 书店 </option> 


«option value-"http://www.joy.com"»&nbsp; &nbsp; 卓越 网 </option> 

«option value-"http://www.shanghaibooks.com"»&nbsp; &nbsp; 上 海 书城 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; «/option» </select> 


50 </fieldset> 
51 </form> 

52 </div> 

53 «/div» 

54 </body> 

55 </html> 





RTF 





(3) 把 文档 以 left.php 为 文件 名 保存 
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代码 文件 : main.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 无 涯 网 上 书店 </title> 
<link href="css/main.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 








«div id-"rightbtl" style="font-size:12px" ><br/>&nbsp; &nbsp; &nbsp;«a 
href="#"> 更 多 .</a> </div> 
«div id="rightconnect"> 
«table width-"580" border=" cellspacing-"0" > 
<tr><td width-"55"»«a href="#"><img src-"leftbgl.jpg" /»«/a»«/td» 
«td width="200"> 书 名 :<br/>ISBN:<br/> 出 版 社 :<br/> 原 价 :<br/> 会 员 
价 :<br/></td> 
<td width="55"><a href="#"><img src-"leftbgl.jpg"/»«/a»«/td» 
«td width="200"> 书 名 :<br/>ISBN:<br/> 出 版 社 :<br/> 原 价 :<br/> 会 员 
价 :<br/></td></tr> 
</table> 
</div> 
«div id="rightbt2" style-"font-size:l2px"»«br/»&nbsp; &nbsp; &nbsp; <a 
href="#"> E £..«/a» </div> 
<div id="rightconnect"> 
<table width="580" border= 
<tr><td width="55"><a href="#"><img src-"leftbg.jpg" /></a></td> 
«td width="200"> 书 名 :<br/>ISBN:<br/> 出 版 社 :<br/> 原 价 :<br/> 优 惠 
价 :<br/></td> 













«td width="55"><a href="#"><img src-"leftbg.jpg"/»«/a»«/td» 
«td width="200"> 书 名 :<br/>ISBN:<br/> 出 版 社 :<br/> 原 价 :<br/> 优 惠 
价 :<br/></td></tr> 
</table> 
</div> 
«div id-"rightbt3" style-"font-size:12px"»«br/»&nbsp; &nbsp; &nbsp;«a 
href="#"> 更 多 ..</a> </div> 
<div id="rightconnect"> 
<table width="580" border="0" cellspacing="0"> 
<tr><td width="55"><a href="#"><img src-"leftbg.jpg" /»«/a»«/td» 
«td width="200"> 书 名 :<br/>ISBN:<br/> 出 版 社 :<br/> 评 级 :<br/> 会 员 
价 :<br/></td> 
«td width-"55"»«a href="#"><img src-"leftbg.jpg"/»«/a»«/td» 
«td width="200"> 书 名 :<br/>ISBN:<br/> 出 版 社 :<br/> 评 级 :<br/> 会 员 








(3) 把 文档 以 main.php 为 文件 名 保存 
代码 文件 : linkbottom.html 


(1) 在 Dreamweaver 中 ， 新 
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游 
mm 
ot 


fr:«/td»«/tr» 
</table> 
</div> 
</body> 
</html> 





点 根 文件 夹 下 。 





t PHP 文档 。 

(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 

<!DOCTYPE HTML PUBliC "-//W3C//Dtd HTML 4.01 Transitional//EN" 
"http://www.w3c.org/tr/1999/REC-htm1401-19991224/10ose.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 


<head> 
<tit1le> 无 涯 网 上 书店 </title> 





«meta http-equiv-Content-Type content-"text/html; charset-utf-8"» 


<link href-"css/bottom.css" rel="stylesheet" type="text/css"> 
</head> 
<body> 
<div id="bottom"> 
<table width="780" border=" 
<tr><td width-"220" bgcolor= 


align="right" cellspacing="1"> 





"#FFCC99" rowspan="2"><iframe 


id-"timersFrame" height="80" src="jsq/al jsq pic.php" allowtransparency- 
"true" border="0" marginwidth=0 marginheight=0 frameborder=0 width="220" 


scrolling="no" align="center"> 不 支持 </iframe></td> 

«td width-"88" bgcolor="#FFCC99"> 购买 图 书 </td> 

«td width-"88" bgcolor="#FFCC99"> 付款 方式 </td> 

<td width="88" bgcolor="#FFCC99"> 我 的 订单 </td> 

«td width-"118" bgcolor="#FFCC99"> 退货 条 款 </td> 

«td width-"172" bgcolor="#FFCC99"> 联系 我 们 </td></tr> 

<tr><td width="88" valign="top"> 
«ul»«li»«a href=# target="_blank"> 购 书 流程 </a> </li> 

_blank"> 购 书 发 票 </a> </1i> 


_blank"> 到 货 时 间 </a> </1i> 









<1i><a href="#" target= 





<li><a href="#" target= 
</ul></td> 
«td width-"88" valign-"top"» 
«ul»«li»«a href-"$" target-" blank"> 购 书 卡 </a> </li> 
_blank"> 网 上 支付 </a> </1i> 
_blank"> 邮 局 汇款 </a> </1i> 





Xli»«a href-"$" target- 





<li><a href="#" target- 
</ul></td> 
«td width-"88" valign="top"> 
«ul»«li»«a href-"4" target="_ blank"> 查 询 订单 </a></1i> 
_blank"> 汇 款 招领 </a></1i> 
_blank"> 查 询 账户 </a></1i> 





<li><a href="#" target= 





<li><a href="#" target= 


8 


3 


Ww 


PHP 动态 网 页 设计 与 制作 案例 教程 (第 己 版 ) 


«/ul»«/td» 
«td width-"118" valign="top"> 
«ul»«li»«a href="#" target-" blank"> 无 条 件 退换 </a></1i> 
<li><a href-"$" target-" blank"> 退 换 规定 </a></1i> 
<li><a href="#" target-" blank"> 退 换 地 址 </a></1i> 
«/ul»«/td» 
«td width-"172" valign="top"> 
<ul><1i> 电 话 : 021-8888888 </li> 
<1i> 工 作 时 间 : 8:00-17:00 «/1i» 
<1i> 地 址 : xxxxxxxx «/li» 
</ul></td></tr> 
<tr><td colspan="6"><iframe border=0 name="copyright" align="center" 
marginwidth=0 marginheight=0 src="bottom.html" frameborder=0 width="780" 
scrolling=no height="70"> 不 支持 </iframe></td></tr> 
</table> 
</div> 
</body> 
</html> 


(3) 把 文档 以 linkbottom.html 为 文件 名 梨 存 在 站 点 根 文件 夹 下 





代码 文件 ，bottom.html 


(1) 在 Dreamweaver 中 ， 新 建 HTML 文档 
(2) 单 击 “ 代 码 ” 标 签 , 切换 到 “代码 ”视图 , -输入 如 下 代码 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 无 涯 网 上 书店 </tit1le> 
<link href-"css/bottom.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="copyright"> 
Copyright@2016 wuyabook@com 无 涯 网 上 书店 版 权 所 有 <br/> 
《中 华人 民 共 和 国电 信和 与 信息 服务 业务 经 营 许可 证 》 编 号 : 沪 ICP 证 xxxxxx 号 <br/> 
建议 浏览 器 分 辩 率 ，1024x768 
</div> 
</body> 
</html> 


(3) 把 文档 以 bottom.html 为 文件 名 保存 看 








% 根 目录 下 。 
e 链接 


(D 网 页 left.php 的 实现 参见 7.3 节 。 
© 网 页 main.php 的 实现 参见 7.6 节 。 
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3.8 ”网 站 主页 中 的 链接 策略 





ak RAFA 


1. 导航 条 

主页 index 中 包含 了 3 个 导航 栏 。 

(1) top.php 中 的 通用 导航 栏 。 

(2) top.php 中 的 特色 导航 栏 。 

(3) linkbottom.php 中 的 常见 问答 导航 栏 。 








2. 搜索 栏 

在 leftphp 中 的 查询 导航 中 包含 THOME ERE RU 
3. 友情 链接 S 

fE left.php 中 €— —'À 

4. 栏目 页 面 :A 

在 main.php 中 通过 超级 链接 能 查询 到 更 多 的 特色 栏 目的 图 书信 息 。 

5. 计数 器 链接 PN 





在 linkbottom php *ífi/e ESA iH 区 域 通过 溯 动 框 荣 链 接 网 页 实现 了 网 页 计数 器 的 功能 。 


Qus Kt 


| 34 PHP 语言 基础 
3.4.1 PHP 的 程序 结构 
一 个 完整 的 PHP 程序 包括 界定 符 、 语 句 和 注释 。PHP 程序 包含 在 网 页 文件 中 。 
1. PHP 的 界定 符 


PHP 程序 的 界定 符 有 4 种 ， 语 法 格式 如 下 。 
1) 常用 方法 


<? 





PHP 语句 ; 
2» 
2) 推荐 方法 


«php // 之 间 没 有 空格 
PHP 语句 ; 


?» 


3) HTML 标签 
<script Language-"php"» 
PHP 语句 ; 
</script> 


4) 与 ASP 相同 


<% 





PHP 语句 
$> 


2. 语句 

PHP 的 程序 是 由 语句 组 成 的 。 按 照 语 句 的 功能 ， 可 分 为 以 下 几 种 。 

(1) 声明 语句 。 

(2) 赋值 语句 。 

O 流程 控制 语句。 RA 

(4) 函数 调用 语句 。 X3 
LN 法 与 C 语 言 一 样 ， 在 PHP PAS RANGER. | 一 


PHP 通过 语句 组 可 实现 数据 输入 、 数据 处 理 和 数据 输出。 
用 户 在 网 页 中 输入 数据 ， 可 以 在 网 让 后 面 附带 字符 串 ， 如 
http: //Fili/access .php?data1- UAR A (fJ — 26.. 
也 可 以 利用 表单 ， 如 一 
<form E ES 
可 见 ， 网 页 间 传 递 数据 的 方式 有 以 下 丙种 。 
GET: 将 数据 Lr URL 地 址 后 面 送出 去 
POST. 将 数据 打包 ， 以 封包 方式 送出 。 
PHP 数据 处 理 的 语句 包括 流程 控制 语句 (分 支 控制 语 句 、 循 环 控制 语句 和 跳 转 控制 语句 ) 
和 函数 调用 语句 。 
PHP 的 函数 包括 内 路 函数 和 自 定义 函数 两 种 ， 有 具体 内 容 参 见 4.3 节 。 
PHP 数据 输出 的 语句 包括 echo 语句 、print 函数 和 sprint 函数 ， 语 法 格式 为 






































echo "要 输出 的 字符 串 1"，" 要 输出 的 字符 串 2".…; 

print ("要 输出 的 字符 串 1"; 

sprint ("$d$s$10.3f$",a,b,c); // d -十 进 制 整数 ，s -字符 串 ，f£ - 浮 点 数 ， 共 10 位 ， 
有 3 位 小 数 


Lun 
print 和 echo 两 者 的 功能 几乎 是 完全 一 样 的 ， 都 是 一 个 语言 结构 , 有 无 括号 均 可 使 用 ,如 echo 或 


echo()，print 或 print()。 两 者 之 间 的 区 别 : 在 echo 函数 中 ， 可 以 同时 输出 多 个 字符 串 ， 而 在 print i 
数 中 则 只 可 以 输出 一 个 字符 囊 。 


ES 
o i TN 
3. ox 


PHP 代码 中 的 注释 不 会 被 程序 读 取 和 执行 。 它 唯一 的 作用 是 供 代码 编辑 者 阅读 。 
PHP 支持 C、C++ 和 UNIX 风格 的 注释 方式 。 格 式 如 下 所 示 : 








S ii C, c++ 风格 中 的 多 行 注释 
MES c++ 风格 中 的 单行 注释 
LES UNIX 风格 中 的 单行 注释 


S un 
上 面 这 3 AGAETXUOAUR, SEHR DLL, AGES AULEHOHERIOUR BAUER i 
RAT: X 
O 使 其 他 人 理解 正在 做 的 工作 . l 
Q 提醒 自己 做 过 什么 ， 


4. 文件 名 AN 
PHP 文件 名 中 只 使 用 字母 、 数 字 和 英文 状态 下 的 破 折 号 。 文 件 的 扩展 名 是 ,php。 
3.4.2 PHP 的 句法 结构 


gd 


PE A niin 以 字符 或 下 划 线 头 ， 包 括 预 
定义 常量 和 自 定义 常量 。 

预定 义 常量 是 PHP 向 它 运 行 的 任何 脚本 提供 的 预先 定义 常量 。 但 很 多 常量 都 是 由 不 同 
的 扩展 库 定义 的 ;只 有 在 加 载 了 这 些 扩展 库 时 才 会 出 现 ， 或 者 动态 加 载 后 ， 或 者 在 编译 时 
Gg dX Y um 

PHP. VERSION 指 显示 目前 使 用 的 PHP 解释 器 的 版 本 。 

PHP. OS 指 显示 服务 器 的 操作 系统 名 称 。 

一 DIR_ 指 文件 所 在 的 目录 。 

一 FILE_ 指 文件 的 完整 路 径 和 文件 名 。 

一 LINE_ 指 文件 中 的 当前 行 号 。 

_FUNCTION_ 指 函数 名 称 。 

TRUE, FALSE 也 是 系统 内 置 的 常量 。 


自 定义 常量 是 用 户 根据 需要 由 自己 定义 的 常量 ， 诸 法 格式 如 下 : 


bool define ( string name, mixed value [, bool case insensitive]) 


Lun 
O 常量 默认 为 大 小 写 敏 感 。 按照 惯例 ， 常 量 标识 符 总 是 大 写 的 - 
Q 一 个 常量 一 旦 被 定义 ， 就 不 能 再 改变 或 者 取消 定义 。 
© 不 能 重新 定义 已 经 定义 过 的 常量 。 
QD 常量 的 作用 范围 是 全 局 ， 即 一 旦 被 定义 ， 常 量 贯穿 整个 脚本 。 


N 
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2. 变量 
变量 指 用 户 定义 的 且 随 着 程序 的 执行 而 改变 的 量 ， 是 存储 信息 的 容器 。PHP 中 的 变量 
包括 预定 义 变量 和 自 定义 变量 。 
预定 义 变量 是 PHP 中 预先 定义 的 系统 内 置 变量 。 例 如 : 
SGLOBALS 指 包含 一 个 引用 指向 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 。 
$_SERVER 指 由 Web 服务 器 设 定 或 者 直接 与 当前 脚本 的 执行 环境 相关 联 。 
$_FILES 指 经 由 HTTP POST 文件 上 传 而 提交 至 脚本 的 变量 。 
$ GET 指 经 由 HTTP GET 方法 提交 至 脚本 的 变量 。 
$ POST 指 经 由 HTTP POST 方法 提交 至 脚本 的 变量 。 
$ REQUEST 指 经 由 GET、POST 和 COOKIE 机 制 提交 至 脚本 的 变量 。 
$_COOKIE 指 经 由 HTTP Cookies 方法 提交 至 脚本 的 变量 。 
$ SESSION 指 当前 注册 给 脚本 会 话 的 变量 。 
S_ENYV 指 执行 环境 提交 至 脚本 的 变量 ， "XN 


eum A 
相关 内 容 和 参见 5.4、5.5 节 。 ^E 
自 定义 变量 是 用 户 根据 需要 自己 定义 的 变量 语法 格式 如 下 : 
$varname A K» á 
Lun : z - 
PHP 变量 规则 : NE 
(D 变量 以 $ 符号 开头 ， 其 后 是 变量 的 名 称 ， 
Q 变量 名 称 只 能 包含 字母 一 数字 、 字 符 和 下 划 线 \(A-z、0-9 以 及 _). 
© 变量 名 称 必须 以 字母 或 下 划 线 开 头 ， 对 大 小 写 获 滞 (Sx 与 SX 是 两 个 不 同 的 变量 ) 。 
© 变量 名 称 直 能 以 数字 开头 。 
在 PHP 程序 和 函数 中 使 用 变量 是 直接 指定 一 个 值 给 变量 而 不 加 声明 ， 如 


$varname-value; 


Lun 

使 用 这 样 的 方式 就 创建 了 变量 ， 即 设置 了 一 个 存储 信息 的 容器 . PHP 根据 它 的 值 ， 自 动 把 变量 转换 
为 正确 的 数据 类 型 。 

给 变量 赋值 有 两 种 方式 : 传 值 赋值 和 传 地 址 赋值 . 

CD 传 值 赋值 ， 将 一 个 表达 式 赋予 一 个 变量 时 ， 整 个 原始 表达 式 的 值 被 赋 到 目标 变量 。 

回 传 地 址 赋值 : 形 如 Sa=&Sb， 新 的 变量 Sa 引用 了 原始 变量 Sb， 可 认为 Sa 是 $b 的 别名 。 

在 网 页 中 输出 变量 的 格式 如 下 : 


<?php echo $varname; ?> 或 <?php -$varname ?> 


使 用 上 述 格式 也 可 以 将 变量 的 值 直接 输出 到 浏览 器 上 。 



































oo 
eo 
" 
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变量 的 作用 域 即 它 定义 的 有 效 范围 有 三 种 : 全 局 的 、 局 部 的 和 静态 的 。 全 局 变量 是 能 
在 所 有 页 面 都 可 使 用 的 变量 ， 如 预定 义 变量 都 是 全 局 变量 ， 局 部 变量 只 能 在 它 定义 的 页 面 


和 函数 中 使 用 ， 而 静态 变量 所 存储 的 信息 都 是 最 后 一 次 被 更 新 时 所 包含 的 信息 。 


加 









































ou 
相关 内 容 参 见 44、5.5、6.4 节 . 


3. 运算 符 
PHP 具有 C, CHAI Java 中 常见 的 运算 符 。 这 些 运算 符 也 有 优先 权 的 问题 。 
PHP 中 的 运算 符 包 括 以 下 几 种 : 
(1) 算术 运算 符 : 主要 用 来 进行 数学 运算 ， 如 表 3.1 所 示 。 
R31 算术 运算 符 





mo 明 





+ 加 计算 10 加 4， 结 果 为 14 

- 减 计算 10 减 4， 结 果 为 .6 ( 注 : 放 在 数值 前 ， 产 生 相反 数 ) 
* 乘 计算 10 乘 4， 结 果 为 40 

/ 除 计算 10 除 以 4, £80 2.5 

% 取 余数 计算 10 除 以 4 的 余数 ， 结 果 为 2 


(2) 字符 运算 符 : 参与 运算 的 数据 是 字符 串 ， 只 有 一 个 运算 符 “.”， 其 作用 是 连接 两 
个 字符 串 ， 如 "ab"."cc"， 把 “.” 前 后 的 字符 串 连接 为 新 字符 串 ， 结 果 为 "abcc"。 

G) 比较 运算 符 : 判断 运算 符 前 后 的 量 的 大 小 ， 如 表 32 所 示 。 
X32 比较 运算 符 





inii 
» 
m 
E 
K 


> RF 当 $a 大 于 $b 时 ， 值 为 TRUE， 耕 则 为 FALSE 
< 小 于 当 $a 小 于 Sb 时 ， 值 为 TRUE， 否则 为 FALSE 


x 不 大 于 /不 小 于 | $a<=$b/$a>=$ | “$a 小 于 /大 于 或 等 于 $b 时 , 值 为 TRUE, 否则 为 FALSE 
|<> 不 等 于 当 $a 与 $b 不 等 时 ， 值 为 TRUE， 厂 则 为 FALSE 


== 全 等 (完全 相同 ) = 当 $a 等 于 Sb 时 ， 且 它们 类 型 相同 ， 则 返回 true 
= _| 不 全 等 (完全 不 相同 )| Sat— 当 $a 不 等 于 Sb 时 ， 且 它们 类 型 不 相同 ， 则 返回 _true 


m 9 说 gm 
-$b 


一 等 于 "($a 等 于 Sb IM, {H TRUE, MW FALSE 
a! 














(4) 赋值 运算 符 : 只 有 一 个 运算 符 “=”， 把 其 右边 表达 式 的 值 赋 给 左边 的 变量 ， 如 
$a=10+4， 把 10 加 4 的 结果 14 赋予 变量 $a。 

(5 JESipe SERE: 通常 用 来 测试 真 假 值 ， 如 表 3.3 所 示 。 
X33 BRIAN 





























运算 符 | 意 X m 例 说 明 
And && 与 $a And Sb 或 Sa && Sb | 当 $a 和 S$b 同 为 TRUE 时 , 值 为 TRUE, 否则 为 FALSE 
Or || 或 Sa Or Sb 或 $a || $b 当 $a 和 $b 同 为 FALSE 时 , 值 为 TRUE, 否则 为 FALSE 
Xor 异 或 ”| $a Xor $b 当 $a 和 $b 不 同 为 TRUE sk FALSE 时 ， 值 为 TRUE 
! 非 !$a ?4$a 为 TRUE 时 ， 值 为 FALSE ， 否 则 为 TRUE 
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(6) 数组 运算 符 : 用 于 进行 一 些 快速 的 数字 运算 ， 如 表 3.4 所 示 。 
X34 数组 运算 符 


运算 符 意 x 说 明 



































* 联合 将 Sa 和 Sb 联合 ， 但 不 覆盖 重复 的 键 

=x 相等 当 $a 与 Sb 有 相同 的 键 / 值 时 ， 返 回 true 

— 全 等 当 $a 和 Sb 有 相同 的 键 / 值 时 且 数 据 类 型 相同 时 ， 返 回 true 
ad 不 相等 当 $a 与 Sb 键 / 值 有 一 个 不 同时 ， 返 回 true 

<> 不 相等 当 $a 与 Sb 键 / 值 有 一 个 不 同时 ， 返 回 true 

!== 不 全 等 ?4$a 和 S$b 完全 不 同时 ， 返 回 true 





(7) 简约 运算 符 : 类 似 于 C 语言 ， 本 质 是 给 最 左 侧 的 变量 赋值 ， 如 表 3.5 所 示 。 
表 3.5 简约 运算 符 


运算 符 说 "m 说 明 
a= | $at=Sb 等 价 于 $a=Sa+Sb | a- |sa&-sb 等 价 于 Sa=Sa&Sb 
一 “| Sa-=$b 等 价 于 9a=Sa-Sb | 上 上 SaESb 等 价 于 Sa=Salb 
*- | Sa=Sb 等 价 于 Sa=SarSb Sa^-Sb 等 价 于 Sa=$a^Sb 
i Sa/-$b 等 价 于 $a=$a/$b >>=) | Sa>>=$b 等 价 于 $a=$a>>$b 
%= $a%=S$b 等 价 于 $a=$a%b <<=  |Sacc-Sb 等 价 于 $a=$a<<$b 





S$a 一 等 价 于 $a=$a-1 先 返 回 值 , 再 作 运算 
一 $a 等 价 于 $a=$a-1 先 作 运算 ， 再 返回 值 


$a++ 等 价 于 Sa=$a+l AREE, PARESE 
++$a 等 价 于 $a=$a+1 先 作 运算 , 再 返回 值 
= Sa.-Sb 等 价 于 $a=$a.Sb 


(8) 递增 递减 运算 符 如 表 -3.6 所 示 。 


表 3.6 递增 北 沽 运算 符 
i 
à 








后 加 


义 
返回 $a， 然后 将 $a 的 值 减 


(9) 其 他 运算 符 如 表 3.7 所 示 。 





表 3.7 其 他 运算 符 












明 





示 9 说 
Sa?Sb:$c 若 a HEWA b, TWA c 

















s | 定义 变量 Sa 定义 变量 a 

& | 取 变 量 的 地 址 &Sa 获取 定义 变量 a 的 地 址 

@ | 隐藏 错误 消息 @echo $4 — 隐藏 函数 echo 执行 时 的 错误 消息 
- | 引用 对 象 的 方法 或 属性 Objl->name | 引用 对 象 Objl 的 属性 name 














定义 数组 元 素 的 值 g=> "asd" 数组 下 标 为 g 的 元 素 的 值 是 asd 











高 到 低 ， 如 表 3.8 所 示 。 





(10) 运算 符 的 优先 级 : 
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表 3.8 运算 符 的 优先 级 




















优先 级 | 运算 符 | 说 m 算 符 P o" 
1 逻辑 “ 非 ” 逻辑 “与 
2 |e — [aue x DEP 
3 [toss [R R BR LLAQAE | 赋值 简 咯 运算 
4 + 一 . | 加 、 减 、 连 接 ja b 
; |< [WF 不 大 于 
> >= 大 于 、 不 小 于 逻辑 “或 ” 
6 |= - | 等 了 .不 等 














3.4.8 PHP 的 数据 类 型 

1， 基 本 数据 类 型 

PHP 支持 8 种 原始 类 型 ， 包 括 4 种 基本 类 型 ， 整 型 (integer)s 浮 点 型 (float)( 浮 点 数 ， 也 
fE double)、 字 符 串 (string) 和 布尔 型 (boolean); 两 种 复合 类 型 : 数组 (array) 和 对 象 (objecb; 
黄种 特殊 类 型 ， 资 源 (resource) 和 NULL。 为 了 确保 代码 的 易 读 性 ， 常 使 用 3 种 伪 类 型 ， 包 
括 混合 (mixed)、 数 字 (numbeD 和 回馈 (callback)。 

(1) 整 型 (integeD。 整 型 值 可 以 用 十 进 制 、 二 六 进 制 、 八 进 制 或 八进制 符号 指定 ， 前 面 
可 以 加 上 可 选 的 符号 (- 或 者 +)。 如 果 用 八进制 符号 ， 数 字 前 必须 加 上 0( 零 ); 用 十 六 进 制 符 
号 ， 数 字 前 必须 加 上 0x; 用 二 进 制 符号 ， 数 字 前 必须 加 :0b。 

(2) 浮 点 型 (float、double 或 real numbers) 可 以 用 以 不 语法 定义 : 





<?php 

$a = 1.234; // 包 含 小 数 部 分 

$a = 1.234e3; // 采 用 科学 记 数 法 =1 .234*103=1234 
$a = 1.234E-4; //=1.234*10-*=0.0001234 

?» 


(3) 字符 串 (string)。 用 ""( 双 引号 ) 或 " 单 引号 ) 界 定 的 若干 个 (大 于 或 等 于 0) 字 符 构 成 的 
集合 ， 如 "aBcd""3.14159" 和 "中 国 "。 
当 用 双 引 号 或 者 定 界 符 指定 字符 串 时 ， 其 中 的 变量 会 被 解析 。 要 想 使 用 、\、" 和 换行 
符 、 回 车 符 、 水 平 制 表 符 等 控制 字符 ， 必 须 使 用 “\” 转 义 ， 如 表 3.9 所 示 。 
表 3.9 转 义 字符 









水 平 制 表 符 
美元 符号 








Wan 


@ 一 个 字符 串 除了 用 单 引号 、 双 引号 界定 外 , 还 可 以 使 用 heredoc 语法 结构 和 nowdoc 语法 结构 ( f 


PHP 5.3.0 起 ) 表达 。 


© 字符 串 会 被 按照 与 该 脚本 文件 相同 的 编码 方式 来 编码 。 
© 在 单 引号 字符 串 中 的 变量 和 特殊 字符 的 转 义 序列 将 不 会 被 替换 。 
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(4) 布尔 型 (boolean)。 表 达 式 的 真 值 ， 可 以 为 TRUE HÈ FALSE. 

TE PHP 中 ， 将 以 下 几 个 方面 视 为 FALSE， 其 他 一 切 都 视 为 TRUE。 
(D 关键 字 FALSE fI NULL. 

Q se o 和 浮 点 数 0.0。 

@ 0 作为 字符 串 (0 或 "0")。 

@ 空 字符 串 ( 中 间 没 有 空格 的 " "或 ")。 

© 具有 0 个 元 素 的 数组 。 

2. 数组 


PHP 中 的 数组 实际 上 是 一 个 有 序 对 ， 即 把 values 映射 到 keys 的 类 型 。 
(1) 数组 的 结构 如 下 : 














/Wkeys 是 数组 的 键 名 , 可 以 是 一 个 非 负数 ， 也 可 以 是 一 个 字符 ; values 
是 对 应 数组 键 名 keys 的 值 CNN 


$bname [keys]-values 





(2) 数组 的 创建 。 可 以 通过 在 方 括号 内 指定 键 名 来 给 数组 赋值 的 方法 创建 数组 ， 语 法 
格式 如 下 : 
$ 数 组 名 [索引 1 值 ]= 指 定 值 GOL 
或 者 使 用 函数 -array( ) 来 创建 数组 。 语 法 格式 为 

array akray (Mixed 10) TA 

另外 ， 还 可 以 通过 以 下 方法 创建 数组 或 给 数组 的 元 素 赋值 。 
(1) 使 用 运算 符 => 指 定数 组 元 素 的 值 。 例 如 : 


$bname=array ("PHP 案例 教程 ", 4=>"ASP 案例 集锦 ", "ISP 专家 指南 ) "; 
bname[0]-"PHP 案例 教程 "， Sbname[4]-"ASP 案例 集锦 "， Sbname[5]-"JSP 专家 指南 "; 


D 索引 可 以 是 数字 ， 也 可 以 是 字符 。 例 如 : 


S$bname ["4-2-8"]="PHP 案例 教程 "; 
Sbvalue["PHP 案例 教程 "] =45.0; 


G) 数组 元 素 的 值 可 以 是 不 同 的 数据 类 型 。 例 如 : 
$bname[0] -"PHP 案例 教程 " 
$bname ["PHP 案例 教程 "]=45.0 
PHP 也 可 以 定义 多 维 数组 , 即 每 个 数组 的 元 素 再 细 分 为 多 个 数组 元 素 , 如 $bname[2][1]， 
它 的 结构 如 下 所 示 。 多 维 数组 的 创建 和 使 用 方法 与 一 维 数组 相同 。 
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一 维 数组 | Sbname[0] Sbname[1] Sbname[2] 
- 维 数组 | m u] [0] u] [0] | m 
值 | PHP 案 例 教程 | 45.0 | AsP 案 例 集锦 | amo | JSP 专家 指南 | sos 
对 应 的 元 素 为 


Sbname[0][0]- "PHP 案例 教程 ” Sbname[0][1]= 45.0 

Sbname[1][0]7 "ASP 案例 集锦 ” Sbname[1][1]= 48.0 

Sbname[2][0]- "JSP 专家 指南 " ^ Sbname[2][1]- 50.5 
(4) 数组 的 使 用 。PHP 定义 了 一 组 数组 函数 。 最 常用 的 如 下 : 


int count(mixed var [, int mode]) // 统 计数 组 中 元 素 的 个 数 
mixed key(array array) // 取 得 目前 数组 指针 所 指 元 素 的 索引 值 
mixed current(array array) // 取 得 目前 数组 指针 所 指 元 素 的 值 
list ($varl, $var2..)=each (array array) // 把 数组 中 的 值 赋 给 一 些 变 量 
mixed next (array array) // 将 数组 指针 移 至 下 一 个 数组 元 素 
3. 对象 
wouws 


相关 内 容 参 见 7.4 H. 
4， 获 取 数 据 类 型 和 改变 数据 类 型 
通过 一 组 内 置 函 数 能 判断 变量 的 数据 类 型 ， 也 可 以 强制 转换 数据 类 型 ， 语 法 格式 为 


(int) | (integer) $varname; // 转换 成 整 型 
(bool) | (boolean) $varname; /7 转换 成 布尔 型 
(float)|(double)| (real) $varname; // 转换 成 浮 点 型 
(string) $varname; // 转换 成 字符 串 
(array) $varname; // 转换 成 数组 
(object) $varname; // 转换 成 对 象 


3.444 PHP 的 控制 语句 





PHP 程序 都 是 由 语句 组 成 的 。 除 了 赋值 语句 、 函 数 调用 语句 外 ， 使 用 最 多 的 就 是 流程 
控制 语句 ， 主 要 包括 条 件 语 句 、 循 环 诸 句 和 跳 转 语 句 及 包含 诸 句 。 


l. 条 件 语句 














条 件 语句 有 4 种 形式 : if, if...else、if...elseif...else 和 switch. 
Dif ilf) 





if (expr) { // expr 是 一 个 条 件 表达 式 
statement; // 语 句 块 
“说 明 


当 条 件 expr 为 真 时 ， 执 行 语句 块 statement; 否则 执行 语句 块 下 面 的 语句 。 
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O 当 语 句 块 中 只 有 一 行 语句 时 ， 人 可 以 省 略 。 
O 证 语句 可 以 谈 套 在 其 他 证 语句 中 ， 这 给 程序 不 同 部 分 的 条 件 执 行 提供 了 充分 的 弹性 。 


示例 3-1 
«?php 
Sia in; 
if ($id==""){ 
Serrmsg-"ID 字段 不 可 为 空 自 1"; 
echo "错误 信息 :".$errmsg ; 
} 
2> 








错误 信息 : ID 字段 不 可 为 空白 ! 


2) if...else 
if(expr)( 
statementl;  //i&ígjk1; 
} 


else( 
statement2; ”// 语 句 块 2; 


} 
un 


当 条 件 expr 为 真 时 ， 执 行 语句 块 statementl; 否则 执行 语句 所 statement2. 


示例 3-2 
<?php 
$cardmoney-5; 
if ($cardmoney«10) 
echo " 卡 内 金额 不 足 ! "; 
else 


echo "本 次 购书 后 ， 余 额 为 ， Yi0.8"; 





卡 内 金额 不 足 ! 


3) if...elseif...else 
if (expr1)( 
statementl;  // 语句 块 1; 
) 


elseif (expr2)( 
statement2;  // 语句 块 2 
} 


elset 
statement3;  // 语句 块 3 
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S un 
当 条 件 exprl 为 真 时 ， 执 行 语句 块 statement1; 否则 当 条 件 expr2 为 真 时 ， 执 行 语句 块 statement2， 
否则 ， 执 行 语句 块 statement3。 


<?php 

Spassword-"1234"; 

$confirm-"123456", 

if (strlen ($password)>10 or strlen($password)«6)( 
$errmsg=" 请 输入 6 一 10 个 字符 的 密码 ! "7 
echo "错误 信息 : ".Serrmsg ; 

} 

else if($password<>$confirm){ 
$errmsg=" 请 重新 确认 密码 ! "; 


echo "错误 信息 : ".Serrmsg; 


?> 
运行 结果 


错误 信息 : 请 输入 6 一 10 个 字符 的 密码 ! 


4) switch 


switch (expr) { 
case "valuel":  // valuel 为 表达 式 的 可 能 取 值 
statementl; break; 


case "value 2":  // value2 为 表达 式 的 可 能 取 值 


statement2; break; 


case " value n":  // value n 为 表达 式 的 可 能 取 值 
statement n; break; 
default : 
statement ntl;  // 表达 式 的 值 不 是 valuel.value n 中 任何 一 个 


) 


CAT 

当 条 件 expr 的 值 与 case 后 的 条 件 值 相 同时 ， 执 行 该 case 后 的 语句 块 ， 并 跳出 switch 程序 段 ， 执 行 
switch 下 面 的 一 行 语句 ; 否则 执行 default 后 的 语句 块 ， 在 switch 中 每 个 语句 块 后 必须 有 break， 其 作用 就 
是 跳出 switch; 若 无 break， 程 序 会 继续 执行 下 面 case 中 的 语句 块 . 


<?php 
$day- "Fri"; 
switch ($day) { 
case 1: echo "网 页 制作 ";break; 
case 2: echo "访问 客户 ";break; 
case 'Wed': echo "我 要 shopping";break; 
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case 4: echo "去 健身 房 ";break; 
case "Fri": echo "向 Boss 汇报 工作 ";break; 
default: echo "周末 狂欢 "; 





向 Boss 汇报 工作 
2. 循环 语句 
1) for 


for (exprl; expr2; expr3){ 
statement;  // 循环 体 
} 


APT, 

(D 求 第 一 个 表达 式 exprl 的 值 . 

Q) 求 第 二 个 表达 式 expr2 的 值 。 如 果 值 为 TRUE， 则 继续 循环 ， 执 行 循 环 体 中 的 语句 。 如 果 值 为 
FALSE, MMR. 

@ 在 循环 体 被 执行 后 ， 求 第 三 个 表达 式 expr3 的 值 . 

图 每 个 表达 式 都 可 以 为 空 。expr2 为 空 意味 着 将 无 限 循环 下 去 。 


«?php 
$s-1; 
for ($i=1;$i<=10; $i++) { 
$s*=$i; 
echo "$il-$s <BR>"; 





1!21 

2122 

3!26 

41-224 
512120 
612720 
7125040 
8!-40320 
91!-362880 
10!-3628800 


2) while 


while (expr) { 
statement; // 循环 体 





o : 
i 第 3 章 网 站 主页 设计 与 PHP 基础 
6 -——— is 
CET 

只 要 while 表达 式 expr 的 值 为 TRUE， 就 重复 执行 循环 体 中 的 语句 。 表 达 式 expr 的 值 在 每 次 开始 循 
环 时 被 检查 。 





$i-1; $s-1; 
while($i«-10)( 
$s*-$i; 
echo "$i!=$s <BR>"; 
$i++; 
} 
?» 


3) do...while 


dot VA 
statement;  // 循环 体 pe Te 
}while (expr); 


Lan 
(D 执行 一 次 循环 体 。 
回 判断 表达 式 expr 的 值 ， 为 TRUB 就 在 执行 循环 体 中 的 语句 ;~ 否则 执行 while 语句 下 面 的 一 行 语句 。 


<?php X GA- 
$i-1;$s-1; 
do( AC an 
Xf o Pra 
Ss*-$i; fà 
echo "$i!=$s <BR>"; 
$i++; 
}while ($i<=10) 
?» 





4) foreach 


foreach(array expression as $value) statement 


foreach(array expression as $key => $value) statement 


S un 

(D 第 一 种 格式 遍历 给 定 的 数组 array_expression。 每 次 循环 中 ， 当 前 单元 的 值 被 赋 给 $value 并 且 数 
组 内 部 的 指针 向 前 移 一 步 (因此 下 一 次 循环 中 将 会 得 到 下 一 个 单元 )。 
Q 第 二 种 格式 与 第 一 种 格式 不 同 之 处 是 ， 当 前 单元 的 键 值 也 会 在 每 次 循环 中 被 赋 给 变量 Skey。 








示例 
<?php 
$arr=array ("one", "two", "three"); 
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"re saco D 


reset (Sarr); 
while (list(,$value)-each($arr)) 
echo "Value: $value<br>\n"; 
/ /while 语句 等 价 于 下 面 的 foreach 
foreach ($arr as $value) 
echo "Value: $value<br>\n"; 





运行 结果 _V/ 以 下 内 容 输出 两 次 
Value: one 


Value: two 
Value: three 


3， 跳 转 语句 
1) break 语句 
break; // 无 条 件 终止 目前 正在 执行 的 循环 或 分 支 
2) continue 语句 
continue; // 忽 略 本 次 循环 下 面 的 语句 ， 无 条 件 跳 到 下 一 次 循环 
S un 
(D break 结束 当前 for. foreach. while. do... while 或 者 switch 结构 的 执行 。 
@ 在 循环 结构 用 来 跳 过 本 次 猫 环 中 剩余 的 代码 并 开始 执行 下 一 次 循环 。 


«?php 

for($i-1;$i«-5;$i**)( 3 
if($i==3) break; /7 在 输出 3 次 时 循环 跳出 循环 ， 只 输出 2 次 
echo "$i,OK!<BR>"; 

) 

echo "<BR>"; 

for ($i=1; $i<=5; $i++) { 
if ($i==3) continue; // 在 第 3 次 没有 输出 ， 直 接 跳 到 第 4 次 
echo "$i,OK!«BR»"; 


运行 结果 





5, OK! 
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本 章 介 绍 了 网 站 中 主页 的 设计 与 实现 过 程 和 方法 ， 从 中 体会 到 实现 网 页 的 主要 技术 : 
HTML, CSS 和 JavaScript， 同 时 也 介绍 了 PHP 与 HTML 的 关系 及 PHP 的 句法 结构 、 主 要 
控制 语句 等 基础 知识 。 


ius 





(1) PHP 中 包括 几 个 条 件 语句 ?还 有 其 他 作出 判断 的 方法 吗 ? 
@ 在 switch 语句 中 ，break 命令 的 作用 是 什么 ? 
G) dli Fili PHP 中 的 3 处 语法 错误 : «x 





N- 
实践 项 目 、 XV 
X 

项 目 3-1 二 看 PHP 变量 人 X 
项 目 目标 : 
o) poer ur ree. echo 语句 。 

OE 
S. 

(CD 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 文件 p3-Lphp。 








(2) 将 文件 p3-1.php 存放 到 服务 器 上 的 exercise/ch3 文件 夹 中 。 


id 
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(3) 在 Web 浏览 器 上 , 访问 与 p3-1.php 相关 联 的 URL, 观察 执行 结果 (屏幕 截图 表示 )。 


项 目 3-2 PHP 中 的 计算 

项 目 目标 : 
(1) 创建 一 段 PHP 程序 ， 计 算 一 个 圆 的 面积 。 
Q) 上 载 并 执行 PHP 程序 。 























步骤 : 
(1) 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 文件 p3-2.php: 
«?php 
//PHP :一 个 初学 者 的 程序 
// 计 算 给 定 半径 的 圆 的 面积 





echo "<H2> 项 目 3-2 计算 圆 的 面积 </H2>"; 
$radius-2.0; 
$pi-3.14259; 
Sarea-$pi*$radius*$radius; 
echo "<BR> 半 径 ="; 
echo $radius; 
echo "«BR»jfijfi-"; 
echo $area; 
?> 
(2) 将 文件 p3-2.php 存放 到 服务 器 上 的 exercise/ch3 文件 夹 中 。 
(3) 在 Web 浏览 器 上 ,访问 与 p3-2.php 相关 联 的 URL, 观察 执行 结果 (屏幕 截图 表示 )。 


项 目 3-3 查看 环境 变量 
项 目 目标 : 
(1) 演示 PHP 如 何 使 用 预定 义 变量 。 
(2) 演示 PHP 如 何 通过 echo 语句 将 预定 义 变量 发 送 到 浏览 器 。 
pa n 
(1) 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 文件 p3-3.php， 存 放 到 服务 器 上 
的 exercise/ch3 文件 夹 中 。 





<?php 
// 项 目 3-3 查看 环境 变量 
echo "<BR><B> 浏览 器 :</B>".$_SERVER['HTTP_USER AGENT']; 
echo "<BR><B> 主机 :</B>".$_SERVER['HTTP_HOST']; 
echo "<BR><B> 远程 主机 :</B>".$_SERVERI['REMOTE HOST']; 
echo "<BR><B> 远程 地 址 :</B>".$_SERVER['REMOTE_ADDR']; 
echo "<BR><B> 远程 端口 :</B>".$_SERVER['REMOTE PORT']; 


zm 


(2) 在 Web 浏览 器 上 , 访问 与 p3-3.php 相关 联 的 URL, 观察 执行 结果 (屏幕 截图 表示 )。 
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通过 本 章 的 学 习 ， 能 够 使 读者 : 

(1) 理解 PHP 支持 的 文件 系统 

(2) 掌握 在 PHP 中 使 用 函数 的 方法 。 

(3) 掌握 在 PHP 中 使 用 文件 与 目录 的 方法 : 


FIÈR 


本 章 为 读者 准备 了 以 下 学 习 资源 : 

(1) 示范 案例 : 展示 “网 页 计数 器 ”的 设计 与 实现 过 程 ， 对 应 本 章 的 4.1~4.2 节 。 案 例 
代码 存放 在 文件 夹 “ 教 学 资源 \wuyaVjsq\” 中 。 

(2) 技术 要 点 : 描述 “PHP 的 函数 ”和 “PHP 的 文件 处 理 ” 对 应 本 章 的 4.3~4.5 节 。 
其 中 的 示例 给 出 了 相关 技术 的 说 明 ， 代 码 存 放 在 文件 夹 “ 教 学 资源 \extend\ch4\” 中 。 

(3) 实验 项 目 : 代码 存放 在 文件 夹 “ 教 学 资源 \exercise\ch4\” 中 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 : 

(1) 解读 示范 案例 的 分 析 和 设计 。 

(2) 模仿 练习 : 选择 一 个 PHP 集成 开发 工具 ， 如 Dreamweaver， 按 照 实现 步骤 重 现 案例 。 

(3) 扩展 练习 : 按 实践 项 目的 要 求 ， 先 明确 项 目 目标 ， 再 在 PHP. 集成 开发 环境 中 实现 
项 目 代 码 ， 然 后 对 代码 中 的 PHP 语言 要 素 进 行 分 析 ， 提 升 理 解 和 应 用 能 力 。 

学 习 过 程 中 ， 提 倡 结 对 或 3 人 组 成 学 习 小 组 ， 一 起 探讨 和 研究 案例 的 分 析 和 设计 ， 但 
对 PHP 函数 和 文件 处 理 的 学 习 和 具体 项 目的 实现 还 是 鼓励 能 独立 完成 。 
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本 章 案例 介绍 如 何 设计 、 实 现 和 管理 网 站 计数 器 。 网 站 计数 器 可 以 以 文本 输出 ， 也 可 
以 以 图 像 格 式 输出 ， 其 中 涉及 PHP 函数 和 PHP 文件 处 理 等 相关 知识 。 


S€ 预备 知识 

















4.1 网 站 计数 器 的 设计 


网 页 计数 器 是 用 来 统计 网 站 的 访问 次 数 并 把 结果 公布 在 访问 的 网 页 上 的 一 段 程序 
是 让 Web 访问 者 和 网 页 管理 者 获知 网 页 (站 ) 的 人 气 指数 的 最 直接 的 方法 。 

在 Internet 上 ， 可 获得 免费 的 网 页 计数 器 代码 ， 只 要 把 它 嵌入 网 页 恰当 的 地 方 即 可 。 

网 页 计数 器 既 可 以 采用 文件 来 保存 访问 计数 ， 也 可 以 用 数据 库 实 现 。- - 般 来 说 ， 若 只 
是 对 一 个 网 页 (如 首页 ) 计 数 ， 则 采用 文件 保存 计数 的 方法 : 若 对 网 站 上 多 个 网 页 进行 访问 
计数 ， 则 采用 数据 库 保存 计数 的 方法 。 ， 21、 


VIN 


44.1. 系统 架构 NC i 
1， 网 页 计 雪 器 的 工作 流程 O 小 
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JOHAN HTN TAE Ur LORS 当 有 用 户 访问 该 网 页 时 ， 把 网 页 
的 访问 累计 数 加 1( 也 可 以 加 10, DL rel s Hd CS CE UO n 
页 计 数 器 的 荆 作 流程 如 图 4， 1 rz A : 


































"— ES 
Ex 7 返回 12345 uim 
请 求 浏览 
返回 12346 据 | + 据 
H E 


4.1 网 页 计数 器 的 工作 流程 
S un 
O 用 户 向 服务 器 发 出 访问 请 求 。 
© 服务 器 读 取 该 访问 浏览 次 数 的 计数 ， 加 1 后 ， 向 客户 端 返 回 浏览 次 数 。 
© 服务 器 保存 新 的 浏览 次 数 。 
D 有 新 的 用 户 要 访问 ， 则 重复 以 上 3 步 - 
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o mue (d 
2. 和 解决 方案 
计数 保存 在 文件 或 数据 库 中 ， 计 数 的 过 程 是 向 文件 或 数据 库 读 、 写 数据 的 过 程 ， 计 数 
在 页 面 的 显示 方式 有 两 种 : 文本 方式 或 图 片 方式 。 
主要 算法 如 下 所 示 : 
(1) 数据 文件 ，counter.dat ( 注 : 可 以 不 准备 ， 当 检查 文件 不 存在 时 由 PHP 建立 )。 
(2) 读 出 数据 文件 counter.dat 中 的 数据 ， 算 法 为 
打开 文件 ; 
若 不 存在 ， 则 创建 它 ， 并 以 0 为 初始 数据 ; 
否则 ， 读 出 数据 ; 
关闭 文件 。 
(3) 把 累加 后 的 数据 写 入 数据 文件 counterdat， 算 法 为 
累计 数据 ; 
打开 文件 ; 
写 入 数据 ; XS $ 
关闭 文件 。 NNN SA 
(4) 向 网 页 输出 计数 信息 。 
412 系统 设计 SNL C 
Lo 逻辑 结构 设计 SS 
根据 对 系统 架构 的 描述 ;可 得 网 页 计数 器 的 逻辑 结构 如 图 4.2 所 示 。 






























> iP CRisq pic.php 
Pom) Y "lA, EW RABE 
SN 主页 index.php f 
i 
VER 计数 器 文件 counter.dat 





图 像 文件 mages/jsq0~9.gif 


42 ”网 页 计数 器 的 逻辑 结构 


2. 用 户 界 面 设计 
相应 的 界面 如 图 4.3 所 示 。 


欢迎 您 ! 区 域 : 大 小 为 90pxx220px; 居 项 端 14px; 背景 色 为 扫 99 
网 站 的 第 X 位 访客 ! 文字 : 居中 、 粗 体 ， 大 小 为 14px; 颜色 为 本 C9，1.5 倍 行距 
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Áa X 是 输出 的 计数 器 ， 可 以 以 文本 格式 办 出， 也 可 以 以 图 像 格式 输出 。 
界面 的 表现 样式 对 区 域 大 小 、 背 景 颜色 、 文 字 大 小 、 颜 色 等 加 以 定义 ， 保 存在 jsq.css P. 
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4.2 网 站 计数 器 的 实现 


4.2.1 文本 输出 的 网 页 计数 器 
1， 简 易 页 面 计数 器 


代码 文件 : jsq.css、al_jsq_text.php 


y 
和 CSS 编码 


(1) 确认 站 点 根 目录 下 已 建立 文件 夹 jsq( 若 没有 ， 就 创建 )。 
(2) 启动 Dreamweaver， 新 建 CSS 文档 。 
(3) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 以 下 代码 。 
Gcharset "utf-8"; 
/* CSS Document */ 
*dd {  /* 定 义 计数 器 区 域 样式 */ 

font-size: 14px; 

color: $399; 

text-align: center; 





padding-top: 14px; 
height:90px; 
width:220px; 
font-weight: bold; 
line-height: 150$; 
background-color: #FC9; 





(4) 把 文档 以 jsq.css 为 文件 名 保存 在 jsq/ess 文件 夹 下 。 


"^ PHP 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 以 下 代码 。 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 网 站 计数 器 -文本 格式 输出 </title> 
<link href="jsq.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<?php 
// 数 字 输 出 的 网 页 计数 器 
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$max len-8; 

$CounterFile-"counter.dat"; 

if(!file exists($CounterFile))(  // 如 果 计数 器 文件 不 存在 的 处 理 
$counter-0; 
$cf-fopen($CounterFile,"w"); ， // 打 开 一 个 文件 ， 在 此 先 建立 该 文件 





fputs ($c£,"0") ; // 初 始 化 计数 器 文件 
fclose($cf); // 关 闭 文件 
} 
elsel{ // 取 回 当前 计数 器 的 计数 
Scf-fopen (SCounterFile,"r"); 
$counter-trim(fgets ($cf,$max len)); 
fclose ($cf); 
) 
$countertt; // 把 计数 器 计数 自 增 1 
$cf=fopen ($CounterFile, "w"); // 写 入 新 的 计数 


fputs ($cf, $counter); 
fclose ($cf); 





?» 
«div id Id" align="center"> 
欢迎 您 1<br/> 
本 网 站 的 第 <?php echo $counter; // 输 出 计数 器 计数 ?> 位 访客 ! 
</div> 
</body> 
</html> 





(3) 把 文档 以 al-jsq_text.php 为 文件 名 保存 在 jsq 文件 夹 下 。 
M 

m eng 
al jsq text.php 代码 中 包含 的 变量 及 含义 如 表 4.1 所 示 


表 4.1 al jsq text.php 代码 中 包含 的 变量 及 其 含义 














zo" 含 x 
$max len | 自 定义 变量 。 计 数 的 最 大 位 数 
SCounterFile | 自 定义 变量 。 计 数 存放 的 文件 (路 径 和 文件 名 ) 
Scounter | 自 定义 变量 。 存 放 当 前 计数 的 值 
Scf 自 定义 变量 。 打 开 计 数 存 放 文 件 的 句柄 





ü 


v 链接 


有 关 变 量 的 相关 知识 参见 3.3 3 


代码 中 包含 的 文件 操作 函数 如 表 4.2 所 示 。 
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表 4.2 al jsq text.php 代码 中 包含 的 文件 函数 及 含义 
函 数 名 2 X 





file_exists($CounterFile) 判断 文件 是 否 存 在 








fopen($CounterFile,"w") 


文件 。 若 不 存在 ， 则 建立 








Y 





fopen(SCounterFile,"r") 








若 存 在 ， 则 读 出 文件 的 





fgets($cf,Smax len) 








fputs(Scf,"0") 





fclose(S$cf) 打开 的 文件 








端的 空格 符 





trim(fgets(Scf,Smax len)) 
w g 
有 关 PHP 文件 操作 的 函数 参见 4.3 55. 


2. 用 函数 嵌入 访问 页 的 计数 器 





代码 文件 :al_jsq_fun.php、counter.inc.php 


"^ PHP 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 以 下 代码 。 


«?php 
function counter()( 
$counter-0; // 初 始 化 变量 
$max len-8; 
$1jsexplode("/",$ SERVER["PHP SELF"]); 
$CounterFile-"./counter/".$1j[count ($1j)-1].".dat"; 
if(!file exists (SCounterFile))( // 如 果 目 录 不 存在 ， 先 建立 目录 
if(!file exists (dirname ($CounterFile))) 
mkdir (dirname ($CounterFile),0777); 
$cf-fopen ($CounterFile,"w"); // 建 立 并 初始 化 计数 器 文件 
fputs ($c£,"0") ; 
fclose ($cf); 
) 
else( // 取 回 当前 计数 器 的 计数 
$cf-fopen (SCounterFile,"r"); 
$counter-trim(fgets ($cf,$max len)); 
fclose ($cf); 
} 
$counter++; // 把 计数 器 计数 自 增 
$cf-fopen($CounterFile,"w"); // 写 入 新 的 计数 
fputs ($cf, $counter); 
fclose($cf); 
echo $counter; // 输 出 计数 器 计数 





m 





第 4 章 网 站 计数 器 设计 与 PHP 文件 访问 


Ri 
(D) 多 数 PHP 程序 员 习 惯 把 用 于 include( ) 或 require ( ) 的 文件 扩展 名 命名 为 "inc"。 


回 $CounterFile="./counter/".$lj[count ($1j)-1].".dat"; 把 计数 器 文件 定位 于 当前 脚本 所 在 文件 夹 下 的 
子 文件 夫 counter 里 ， 文 件 以 当前 脚本 名 称 加 “.dat" 为 名 称 ，BP al_jsq_fun.php.dat. 


(3) 把 文档 以 counterinc.php 为 文件 名 保存 在 jsq 文件 夹 下 。 
(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(5) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 以 下 代码 。 


«?php 
require ("counter.inc.php"); 
?» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<title> 网 站 计数 器 -文本 格式 输出 _ 函 数 </title> 
<link href-"jsq.css" rel="stylesheet" type="text/css"> 
</head> 
<body> 
<div id="dd" align="center"> 
欢迎 您 <br /> 
本 网 页 的 第 <?phP counter(); ?> 位 访客 ! 
«/div» 
</body> 
</html> 





(6) 把 文档 以 al_jsq_fun.php 为 文件 名 保存 在 jsq 文件 夹 下 。 


Qras 

(D <?php require("counter.inc.php") ?> 把 计数 器 函数 庶 入 网 页 中 ， 该 段 脚 本 应 该 放 在 <HTML> 标 记 
之 前 ; counterinc.php 保存 在 与 网 页 相同 的 文件 夹 下 ， 否 则 在 require("counterinc.php") 中 要 指明 文件 的 
存放 路 径 。 

回 <?php php counter( ); ?> 调用 函数 counter( )， 并 显示 函数 的 返回 值 . 





有 代码 解读 


al_jsq_fun.php 代码 中 包含 的 变量 除了 表 4.1 所 示 的 之 外 , 还 包含 了 $_SERVER["PHP_SELF"] 这 个 超 全 
局 变量 ， 它 保存 了 当前 运行 脚本 的 名 字 ， 本 例 为 /wuya/jsq/al_jsq_fun.php。 
代码 中 包含 的 文件 操作 函数 除了 表 4.2 所 示 之 外 ， 还 包含 了 表 4.3 中 的 函数 。 
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表 4.3 al jsq fun.php 代码 中 包含 的 文件 函数 及 含义 
A 数 名 $ x 
建立 以 SCounterFile 的 值 为 名 的 目录 ， 即 ./counter， 目 录 的 访问 权 
限 是 可 读 、 可 写 、 可 执行 (最 高 权限 ) 的 
dirname($CounterFile) 返回 路 径 中 的 目录 部 分 
返回 一 个 字符 串 数 组 ， 每 个 元 素 为 $_SERVER[PHP_SELF] 经 "%" 作 
为 边界 分 割 出 的 子 串 ， 本 例 中 $lj=[ , wuya , jsq,al_jsq_fun.php ] 





mkdir(dirname(SCounterFile),0777) 

















explode("/,S SERVER[PHP. SELF]) 





count (Sj) 统计 数组 $ 中 元 素 的 个 数 ， 本 例 中 为 4 





4.2.2 图片 输 出 的 网 页 计数 器 





代码 文件 : al_jsq_pic.php，counter_p.inc.php 
XM XT: /images/jsq0.gif~ jsq 9.gif 
Á/ 
~ 准备 工作 
(1) 在 jsq 中 建立 文件 夹 images. 
(2) 把 图 像 文件 jsq 0.gif~ jsq 9.gif 复制 到 文件 夹 images 中 。 
y 
"^ PHP 编 码 


(1) 启动 Dreamweaver,- 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ,输入 以 下 代码 。 


<?php 
header ("Content type:image/gif"); // 发 送 一 个 HTTP 头 信息 
function counter()( // 决 定 计数 器 的 文件 名 
$counter-0; // 初 始 化 变量 


$1j-explode("/",$ SERVER["PHP SELF"]); 
$CounterFile-"./counter/".$1j[count ($1j)-1].".dat"; 
if(!file exists(S$CounterFile)) ( // 如 果 文 件 不 存在 的 处 理 
if(!file_exists(dirname ($CounterFile)))// 如 果 目 录 不 存在 ， 先 建立 目录 
mkdir (dirname ($CounterFile), 0777); 








$cf=fopen ($CounterFile, "w"); // 建 立 计 数 器 文件 
fputs ($c£, "0") ; // 初 始 化 计数 器 文件 
fclose ($cf); 

} 

else{ // 取 回 当前 计数 器 的 计数 








Scf-fopen($CounterFile,"r"); 

$counter=trim (fgets ($cf,10)); 

fclose ($cf); 
} 
$counter++; // 把 计数 器 计数 自 增 1 
$cf=fopen ($CounterFile, "w"); // 写 入 新 的 计数 
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fputs ($cf, $counter) ; 
fclose ($cf); 


// 格 式 化 计数 器 的 输出 
$temp- (string)$counter; // 转 换 为 字符 串 类 型 
$size=strlen ($temp); // 求 字符 串 的 长 度 
for ($i=0; $i<$size; $i++) { 
$p=substr ($temp, $i,1); // 从 高 到 低 获取 数位 上 的 数字 


echo ("<img src-'"."./images/jsq". ($p).".gif' height-'30' width-'15' 
vspace-'10' align-'middle'»"); 
) 
) //the end of the function 





i 


(D header("Content_type:image/gif"); 告诉 浏览 器 这 个 网 页 含有 .GIF 图 像 文 件 ， 这 行 语句 应 该 放 在 
网 页 的 “<HTML>” 标 记 之 前 。 

@ 10 张 数字 图 片 以 包含 对 应 数字 为 名 称 ， 有 利于 程序 控制 图 片 的 显示 。 

(3) Ssize-strlen(Scounter); 统计 变量 $counter 中 包含 数字 的 企 数 ， 记 录 在 变量 $Ssize v. 

(D 第 24~27 行 ,取得 每 位 上 的 数字 值 ， 作 为 图 片 文件 的 名 称 ， 通 过 img 标记 输出 到 浏览 器 上 ， 

(3) 把 文档 以 counter_p.inc.php 为 文件 名 保存 在 jsq 文件 夹 下 。 

(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 


(5) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 以 不 代码 











<?php 
require("counter p.inc.php"); 
it 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<title> 计 数 器 -以 图 像 格式 输出 </title> 
<link href="jsq.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="dd" align="center"> 
欢迎 您 1<br/> 
本 网 站 的 第 <?php counter () ; ?> 位 访客 ! 
«/div» 


</body> 





</html> 


(6) 把 文档 以 al_jsq_pic.php 为 文件 名 保存 在 jsq 文件 夹 下 。 
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42.3 ”调试 代码 

1， 测 试 简易 页 面 计数 器 

确认 al_jsq_text.php、jsq.css 已 在 服务 器 访问 文件 夹 (如 ci\htdocs\wuya 或 c:\appservViwww\ 
wuya) 的 子 文件 夹 jsq 下 。 

启动 浏览 器 ， 输 入 http://localhost/wuya/jsq/al_jsq_text.php， 单 击 “ 转 到 ”按钮 ， 可 见 如 
图 4.4 所 示 的 效果 。 单 击 “ 刷 新 ”按钮 ， 可 观察 到 浏览 器 中 数字 的 变化 。 








欢迎 您 ! 
本 网 站 的 第 1 位 访客 ! 


44 al_jsq_textphp 的 预览 效果 


LN 注 观察 子 文件 夫 jsq 的 变化 . 可 见 增加 了 文件 counterdati- 在 “记事 本 ”中 打开 它 ， 查 看 数字 的 变化 。 

2， 测 试用 函数 谋 入 访问 页 的 计数 器 。 。“、 

确认 al_jsq_fun.php、counterinc.php 已 在 服务 器 访问 文件 夹 ( 如 ci\htdocs\wuya 或 
ci\appserv\ www\wuya) 的 子 文件 夹 jsq Fo 

在 浏览 器 的 地 址 栏 内 输入 httpXWiocalhostwuya/isq/al_jsqd-_fun.php， 单 击 “ 转 到 ”按钮 ， 
可 见 如 图 4.4 所 示 的 效果 。 单 击 “ 刷 新 ”按钮 9 次 ， 可 观察 到 如 图 4.5 所 示 的 数字 变化 。 

i xem | 
本 Rn 从 访客 
eye 
4.5 al jsq fun.php 的 预览 效果 


ÁNA 观察 子 文件 夫 jsq 的 变化 . 可 见 增加 了 文件 夫 counter, HA &, 4X e al jsq. fun php.dat, 在 “ 记 
事 本 ”中 打开 它 ， 查 看 数字 的 变化 。 


3. 测试 图 片 输出 的 网 页 计数 器 

确认 al jsq pic.php. counter pic.inc.php 已 在 服务 器 根 文件 夹 (如 ci\htdocs\wuya 或 
cxappservvwwwwuya) 的 子 文件 夹 jsq 下 。 

在 浏览 器 的 地 址 栏 内 输入 http://localhost/wuya/jsq/al_jsq_pic.php， 单 击 “ 转 到 ”按钮 ， 
可 见 图 4.6(a) 所 示 的 效果 。 单 击 “刷新 ”按钮 多 次 后 ， 可 观察 到 如 图 4.6(b) 所 示 的 数字 变化 。 





欢迎 您 ! 欢迎 您 ! 
aagi i OA 本 网 站 全 访客 ! 
(a) 进入 的 页 面 (b) 刷新 9 次 后 的 页 面 





图 4.6 al jsq text.php 的 预览 效果 


@y 
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4. 网 站 中 jsq 文件 夹 下 的 文件 
网 站 中 jsq 文件 夹 下 的 文件 如 图 4.7 所 示 。 


www > wuya > jsa > [CS al sa funphp dot 
T mte" | Daljsa picphpdat 


images fil jsq6.gif. 
















Bisag 回 jsq79# 
回 jsq2gif 。 回 jsq8gif 
回 jsq9.gif 


O al jsa fun.php. 
[1l jsq picphp. 
L]alisa text php. 

[7 counter.dat. 

C eounterincphp 
C counter pincphp 
fiac 








图 4.7 网 站 中 jsq 文件 夹 下 的 文件 





4.3.1 PHP 函数 概述 


PHP 是 一 门 基 于 函数 的 程序 语言 。 现 妆 过 息 能 执行 特定 功能 的 下 铝 块 。 函 数 在 使 程序 
模块 化 、 简 化 程序 和 代码 重用 等 方面 起 着 重要 作用 ， 同 时 也 使 程序 应 用 更 为 灵活 。 

PHP SD ULT i o itte, ESVE Fri XU C 
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1、， 自 定义 函数 的 语法 格式 l 

IEXRUU OA TERRAS - 个 程序 段 。 语 法 结构 如 下 。 


Sr GEL BN CU 
itg 
[return 返回 值 ] 


1 


) 


Laun 


(1) 函数 命名 的 规则 : @D 函 数 名 不 能 与 预定 义 函数 重 名 ; 回 函 数 名 不 可 以 数字 开头 ; 图 函数 名 不 可 
包含 运算 符 。 

(2) return 语句 把 函数 处 理 的 结果 返回 ， 也 可 以 没有 retum 语句 。 

(3) 函数 名 是 非 大 小 写 敏感 的 ， 不 过 在 调用 函数 时 ， 通 常 使 用 其 与 定义 时 相同 的 形式 。 


2.， 自 定义 函数 的 使 用 
可 以 直接 使 用 函数 名 来 调用 函数 。 含 有 函数 的 PHP 程序 结构 如 下 所 示 。 


«?php 
变量 声明 ; 
语句 抉 ; 
调用 函数 语句 ; 

















ind 


prasami surasan (了 ) 


Wk; 


函数 定义 ; // 可 以 放 在 任 
"r 


qu 明 





© 调用 函数 语句 为 ”函数 名 (参数 传递). 
3. 在 函数 中 传递 参数 
在 PHP 中 ， 参 数 传递 可 以 分 为 传 值 方 


» 
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意 位 置 


(D 在 PHP 程序 中 ， 使 用 函数 是 通过 调用 函数 语句 来 实现 的 。 


式 和 传 址 方式 (也 称 为 引用 传递 )， 默 认 情况 为 








传 值 方式 。 传 值 方式 在 调用 函数 时 将 常量 或 变量 的 值 ( 实 参 ) 传 递 给 函数 的 参数 ( 形 参 )。 值 





传递 的 特点 是 实 参与 形 参 分 别 存储 在 内 存 4 
改变 形 参 的 值 时 ， 实 参 的 值 不 会 发 生变 化 。 











Ph， 是 两 个 互 不 相关 的 独立 变量 。 在 函数 内 部 
传 址 方式 是 实 参与 形 参 共享 一 块 内存 。 当 改 


变 函 数 形 参 的 值 时 ， 实 参 的 值 也 会 发 生 相应 的 变化 定义 引用 传递 参数 时 ， 在 参数 前 面 


加 上 引用 符号 &。 


示例 4-1 


<?php 


function exl($a){ // 定 义 函数 


$att; 
) 


function ex2(&$a)| /7 定义 函数 


$att; 
) 
$x-1; R 
ex1 ($x);  //ft4 


echo "x-".$x."«br/»"; // 输 出 : x=1 


$y=1; 
ex2 ($y); // 传 址 
echo "y=".$y; // 输 出 : x=2 


?» 





gal 
x=2 


ft PHP 的 函数 定义 时 ， 直 接 在 参数 后 面 以 “=” 为 其 指定 值 ， 这 是 为 参数 设置 默认 值 。 





示例 4-2 
«?php 


function ex42($arg-"defult value")( 


echo "参数 值 为 :" .$arg."<br>"; 


} 

ex42(); 

ex42("new value"); 
?> 


@, 
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参数 值 为 :defult value 
参数 值 为 :new value 


PHP 还 支持 可 变 长 度 参 数列 表 。 在 定义 函数 时 ， 不 指定 参数 ， 在 调用 函数 时 ， 可 以 根 
据 需 要 指定 参数 的 数量 ， 通 过 与 参数 相关 的 系统 函数 ， 如 func_num_args()、func_get_arg() 
和 func_get_args() 获 取 参 数 信息 。 


func_num_args(): 返回 传递 给 函数 的 参数 数量 
func get arg: 返回 传递 给 函数 的 参数 列表 
func_get_args0: 返回 一 个 数组 ， 由 函数 的 参数 组 成 
示例 4-3 
<?php 
function ex43(){ 
$numargs-func num args(); 
echo "参数 的 数量 : $numargs«br />\n"; 
if ($numargs»-2) 
echo "第 二 个 参数 的 值 是 : ".func get arg(1). "<br /»in"; 
$arg list-func get args(); 
for($i-0; Si«$numargs; $i++) 
echo "第 ". ($i+1) ." 个 参数 的 值 是 : ".Sarg list[$i]."«br /»in"; 


ex43 (1,2,3); 
?> 


运行 结果 





参数 的 数量 : 3 

第 二 个 参数 的 值 是 : 2 
第 1 个 参数 的 值 是 : 1 
第 2 个 参数 的 值 是 : 2 
第 3 个 参数 的 值 是 : 3 


4. 通 数 中 变量 的 作用 域 








按照 变量 的 作用 范围 ，PHP 函数 中 的 变量 可 分 为 以 下 几 种 。 
(1) 局 部 变量 。 即 在 函数 中 声明 的 变量 。 局 部 变量 仅 在 函数 体内 有 效 ， 在 函数 体外 ， 即 
:用 同名 变量 ， 也 会 被 视 为 一 个 新 变量 。 局 部 变量 的 值 可 通过 return 返回 主 程序 。 

(2) 全 局 变量 。 即 主 程序 中 声明 的 变量 ， 它 不 影响 函数 内 定义 的 变量 。 在 函数 中 使 用 关 









































键 字 global 声明 的 变量 也 被 称 为 全 局 变量 。 格 式 为 
global  ”$ 变 量 名 ; 


示例 4-4 ”全 局 变量 





«?php 
$vall-"Hello world."; 
$val2-"Hello PHP."; 
function ex44()( 
echo $vall."«br»"; 
global $val2; 
echo $val2."«br»"; 
) 
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ex44(); 
res 
运行 结果 
Notice: Undefined variable: vall in XXXM-4.php on line 5 
Hello PHP 


(3) 静态 变量 。 在 函数 中 把 主 程序 中 的 变量 声明 为 静态 变量 后 ， 其 值 不 改变 。 格 式 为 


Static  $ 变 量 名 ; 








示例 4-5 “静态 变量 
<?php 
function ex451()( 
static $count-0; 
$countt-1; 
echo $count."«br»An"; 


) 
function ex452()( 
$count-0; 
$countt-1; 
echo $count."<br>\n"; 
) 
for ($i=0;$i<3; $i++) ex451(); 
for ($i=0;$i<3; $i++) ex452(); 
?> 


1 


rer ww 


4.3.3 PHP 内 置 函数 


PHP 内 部 预先 定义 的 函数 称 为 内 置 函数 ， 常 用 的 内 置 函 数 被 加 载 到 PHP 内核， 只 要 配 
置 好 PHP 运行 环境 就 可 以 使 用 ， 有 的 函数 并 不 是 所 有 系统 都 会 使 用 的 ， 它 们 被 封装 到 外 部 
模块 ， 在 系统 需要 使 用 时 再 激活 这 个 模块 。 例 如 ， 字 符 串 函 数 是 常用 的 函数 ， 而 图 像 函数 
不 常用 ， 被 封装 在 GD 库 中 ， 要 使 用 图 像 函数 就 必须 先 激活 GD 库 。 

PHP 内 置 函数 被 封装 在 不 同 的 函数 库 中 ， 表 4.4 列 出 了 一 些 常 用 的 PHP. 内 置 函 数 库 。 

表 4.4 系统 配置 信息 表 config_info 
库 名 默认 支持 功能 说 明 
对 Apache 操作 的 函数 
对 数组 的 各 种 操作 的 函数 
包含 高 精度 数学 运算 的 函数 
使 用 COM 组 件 的 相关 函数 
对 类 /对 象 操作 












































Apache 函数 库 

数组 函数 库 

BCMath Arbitrary Precision Mathematics Functions 
Windows 的 COM 支持 函数 库 

类 /对 象 函数 库 























库 名 
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( 续 ) 
功能 说 明 


















































时 间 日 期 函数 库 是 对 时 间 和 日 期 操作 

目录 函数 库 是 对 系统 目录 操作 

Error Handling and Logging Functions 是 对 错误 处 理 的 相关 函数 

文件 系统 函数 库 是 对 文件 系统 操作 

FTP 函数 库 是 与 FTP 操作 有 关 的 函数 
Function Handling Functions 是 对 函数 操作 的 函数 

HTTP 相关 函数 库 是 HTTP 头 部 和 Cookie 操作 的 函数 
图 像 函数 库 否 生成 、 修 改 各 种 格式 图 像 的 函数 
LDAP Functions 否 与 LDAP 操作 相关 的 函数 

Mail Functions 是 邮件 发 送 函数 

数学 函数 库 是 各 种 复杂 数学 运算 的 函数 
Microsoft SQL Server Functions f XI MySQL Server 操作 的 函数 
Miscellaneous Functions 是 世 数 定义 等 在 内 的 杂 函 数 
mSQL Functions 对 mSQL 数据 库 & d 


MySQL 函数 库 

Improved MySQL Extension 
Network Functions 

Unified ODBC Functions 
Oracle 8 函数 库 

OpenSSL Functions 

Oracle 函数 库 

输出 控制 函数 

PDF functions 

PHP Options&Information 
PostgreSQL 数据 库 函 数 库 
Program Execution Functions 
Pspell Functions 

正则 表达 式 函数 库 (POSIX 扩展 ) 
Session Handling Functions 
SimpleXML functions 


ze 


i i 


X 





MySQL 数据 库 操作 的 函数 
MySQL 高 级 操作 的 函数 

了 网 络 相关 的 函数 

MySQL 高 级 操作 的 函数 
Oracle 8 数据 库 的 函数 
J OpenSSL 相关 的 函数 
Oracle 数据 库 操作 的 函数 
二 输出 控制 的 函数 

3 PDF 文件 操作 相关 的 函数 
获取 设置 PHP 信息 的 函数 

对 PostgreSQL 数据 库 操作 的 函数 
包含 执行 目录 等 操作 的 函数 
与 拼写 检查 相关 的 函数 

二 正则 表达 式 操作 的 函数 

二 Session 操作 的 函数 

J XML 操作 的 函数 


raja 





yaja 


riži 














SOAP Functions 


4 SOAP 支持 的 函数 





Shockwave Flash Functions 


:成 、 编 辑 Flash 的 函数 





Socket Functions 


xz] ox 


[rd ud e 





3 Socket 通信 相关 的 函数 



































Stream Functions 是 REI) ER c 

字符 串 处 理 函 数 库 是 符 串 操作 的 函数 
Sybase Functions fs 对 Sybase 数据 库 操作 上 
URL 函数 库 是 对 URL 分 析 操作 的 函数 
变量 函数 库 是 对 变量 检测 等 操作 的 函数 
W32API. 函数 库 是 对 W32 API 操作 的 函数 
WDDX Functions 否 对 WDDX 操作 的 函数 





XML 语法 解析 函数 库 


对 XML 文档 解析 的 函数 





XSLT Functions 


对 XSLT 操作 的 函数 





Zip File Functions(Read Only Access) 


对 ZIP 上 压缩 文件 读 操作 的 函数 





Zlib Compression Functions 





| A| 








对 GZIP 压缩 文件 操作 的 函数 
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1.， 数 组 函数 
数组 函数 如 表 4.5 所 示 。 


表 4.5 常用 的 数组 函数 


函 数 名 


功能 说 明 





count(mixed var [, int mode]) 


统计 变量 中 的 数组 元 素 的 数目 





void list(mixed …) 


把 数组 中 的 值 赋 给 一 些 变量 





mixed current(array array) 
mixed prev(array array) 
mixed next(array array) 
mixed reset(array array) 
array each(array array) 


mixed end(array array) 


mixed key(array array) 


mixed current(array array) 


void sort(array array [, int sort_flags]) 

void rsort(array array [, int sort. flags]) 
void asort(array array [, int sort. flags]) 
void arsort(array array [, int sort. flags]) 

int ksort(array array [. int sort. flags]) 

int krsort(array array [, int sort. flags]) 
htmlspecialchars(Sstr [.Squote [.Scharset]]) 
strip tags(Sstr [,Squote style [,Scharset]]) 
htmlentities($str [,Squote style [,Scharset]]) 
html, entity. decode(Sstr [.Squote [.Scharset]]) 
int print(string arg) 

void printf(string format [, mixed args]) 


string sprintf(string format [, mixed args]) 





返回 数组 中 的 当前 单元 的 值 

















返回 数组 内 部 指针 指向 的 前 一 个 元 素 的 值 

返回 数组 内 部 指针 指向 的 下 一 个 元 素 的 值 

将 数组 内 部 指针 倒 回 到 第 一 个 元 素 并 返回 其 值 

返回 数组 中 当前 指针 位 置 的 键 / 值 并 向 前 移动 数组 指针 
将 数组 内 部 指针 移动 到 最 后 一 个 元 素 ， 并 返回 其 值 


返回 数组 中 当前 元 素 的 键 名 

返回 数组 内 部 指针 指向 的 当前 数组 元 素 的 值 

对 数组 元 素 按 数 值 进行 排序 (最 低 到 最 高 ) 

对 数组 元 素 按 数值 进行 逆向 排序 (最 高 到 最 低 ) 

对 关联 数组 按 死 素 值 进行 排序 。 保 留 键 名 到 数据 的 关联 
对 关联 数组 按 元 素 进行 逆向 排序 。 保 留 键 名 到 数据 的 关联 
对 关联 数组 按键 名 排序 ， 保 留 键 名 到 数据 的 关联 

对 关联 数组 按键 名 逆向 排序 ， 保 留 键 名 到 数据 的 关联 
Ko p HTML 标记 当 作 一 般 字符 

去 除 字符 串 中 为 HTML 标记 的 字符 





























HF 1 的 HTML 标记 当 作 一 般 字符 
将 显示 字符 串 转换 为 HTML 标记 

将 数据 输出 到 浏览 器 

将 数据 格式 化 输出 到 浏览 器 

返回 格式 化 数据 





string strtolower(string str) 
string strtoupper(string string) 
string ucfirst(string str) 


string ucwords(string str) 


2. $4 P AE 
字符 串 函 数 如 表 4.6 所 示 。 


udo 


把 字符 串 全 部 转 成 小 写字 母 

把 字符 串 全 部 转 成 大 写字 母 

把 字符 串 的 第 一 个 字符 转 成 大 写字 母 

把 字符 串 每 个 单词 的 第 一 个 字符 转 成 大 写字 母 





表 4.6 
函 数 名 
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常用 的 字符 串 函 数 
功能 说 明 





int strcmp(string strl, string str2) 


>0， 则 Sstrl>$str2; <0， 则 Sstrl<$str2; =0， 则 $strl=$str2 





int strlen(string str) 


返回 字符 串 所 包含 的 字符 个 数 





string substr(string str, int start [, int length]) 





返回 字 度 的 部 


省 略 时 ， 


ee | 指 分 字符 串 , 当 length 








string chop( string str [, string charlist]) 


去 掉 字符 串 末端 的 空格 符 





string trim(string str [, string charlist]) 


string Itrim(string str [, string charlist]) 


去 掉 字 


符 串 首尾 的 空格 符 
串 前 端的 空格 符 








array explode(string separator, string string [, 
int limit]) 

string implode( string glue, array pieces) 

string jion(string glue, array pieces) 
htmlspecialchars(Sstr [,Squote [,Scharset]]) 
strip. tags($str [,Squote. style [,Scharset]]) 
htmlentities($str [,Squote style [,Scharset]]) 
html, entity. decode(Sstr [,Squote [,Scharset]]) 
int print(string arg) 

void printf(string format [, mixed args]) 

string sprintf(string format [, mixed args]) 
string | strtolower(string str) 
string | strtoupper(string string) 
string ucfirst(string str) 


string ucwords(string str) 


3. E Jer fe] i c 
日 期 和 时 间 函 数 如 表 4.7 所 示 。 
表 4.7 

函 数 名 















通过 指定 的 separator( 分 隔 符 ) 将 字符 串 分 解 为 多 个 字符 
串 ， 存 储 在 一 个 指定 的 数组 中 
将 字符 串 数组 中 的 每 一 个 元 素 连接 起 来 ， 成 为 一 个 字符 串 
中 的 HTML 标记 当 作 
FER OU HTML 标记 的 字符 
将 字符 串 中 的 HTML 标记 当 作 一 般 字 符 
E 串 转换 为 HTML 标记 
将 数据 输出 到 浏览 器 
将 数据 格式 化 输出 到 浏览 器 
返回 格式 化 数据 
字符 串 全 部 转换 成 小 写字 母 
f 叫 全 部 转换 成 大 写字 母 
4 的 第 一 个 字符 转换 成 大 写字 母 
把 字符 串 每 个 单词 的 第 一 个 字符 转换 成 大 写字 母 
常用 的 日 期 和 时 间 函 数 
功能 说 明 





string date(string format [, int timestamp]) 


格式 化 时 间 





date default timezone set(timezone) 


设置 用 在 脚本 中 所 有 日 期 和 时 间 函 数 的 默认 时 区 





int time(void ) 


返回 当前 的 UNIX 时 间 截 





array getdate([int timestamp]) 


取得 日 期 和 时 间 信 息 





int strtotime(string time [, int now]) 


其 中 date0 中 format. 字符 的 含义 如 


将 任何 英文 文本 的 日 期 时 间 描 述 解析 为 UNIX. I [03 





表 4.8 所 示 。 
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表 4.8 date() 中 format 字符 的 含义 







































































format 字符 说 明 返回 值 例子 

a 小 写 的 上 午 和 下 午 值 am 或 pm 

A 大 写 的 上 午 和 下 午 值 AM 或 PM 

B Swatch Internet 标准 时 000 到 999 

d 月 份 中 的 第 几 天 ， 有 前 导 零 的 2 位 数字 | 01 到 31 

D 星期 中 的 第 几 天 ， 文 本 表示 ，3 个 字母 Mon 到 Sun 

E 月 份 ， 完 整 的 文本 格式 January 到 December 

g 小 时 ，12 小 时 格式 ， 没 有 前 导 零 1 到 12 

G 小 时 ，24 小 时 格式 ， 0 到 23 

h 小 时 ，12 小 时 格式 ， 01 到 12 

H 小 时 ，24 小 时 格式 ， 有 前 导 零 00 到 23 

i 有 前 导 零 的 分 钟 数 00 到 ,59> 

I 是 否 为 夏令 时 如 果 是 夏令 时 为 1， 和 否则 为 0 

j 月 份 中 的 第 几 天 ， 没 有 前 导 零 1 到 31 

1 星期 几 ， 完 整 的 文本 格式 Sunday 到 Saturday 

L 是 否 为 半年 Ap EA 1, TUN 0 

m 数字 表示 的 月 份 ， 有 前 导 零 01 到 32 

M 3 个 字母 缩写 表示 的 月 份 Jan 到 Dec 

n 数字 表示 的 月 份 ， 没 有 前 导 零 1.54] 12 

o 与 格林 此 治 时 间 相差 的 小 时 数 +0200 

r REC 822) 格 式 的 日 期 Thu, 21 Dec 2000 16:01:07 +0200 

s pus dius 00 到 59> 

S 每 月 天 数 后 面 的 英文 后 级 ，2 个 字符 St, nd, rd 或 者 th。 可 以 和 j 一 起 用 

t 给 定 月 份 所 应 有 的 天 数 28 到 31 

T 本 机 所 在 的 时 区 EST(Eastern Standard Time) 中 国标 准时 间 
从 UNIX 纪元 (January 1 1970 00: 00: 00 

U ARR: . 参见 time() 
GMT) 开 始 至 今 的 秒 数 

w 星期 中 的 第 几 天 ， 数 字 表示 0( 表 示 星 期 天 ) 到 6( 表 示 星 期 六 ) 

W ISO-8601 格式 年 份 中 的 第 儿 周 42( 当 年 的 第 42 周 ， 每 周 从 星期 一 开始 ) 

X 4 位 SERO IAE UY 1999 或 2003 

y 2 位 数字 表示 的 年 份 99 或 03 

z 年 份 中 的 第 几 天 0 到 366 

时 差 偏 移 量 的 秒 数 一 43200 到 +43200 UTC 西边 的 时 区 偏 移 量 总 


函数 getdate() 返 回 的 数组 











是 负 的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 的 


hb 的 键 名 单元 如 表 4.9 所 示 。 
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表 4.9 getdate() 返 回 的 关联 数组 中 的 键 名 单元 









































表 4.10 


函 数 名 


string decbin(int number) 
string dechex(int number) 
string decoct(int number) 





常用 的 数学 函数 
功能 说 了 明 


进 制 转换 为 二 进 制 
- 进 制 转换 为 十 六 进 制 
进 制 转换 为 八进制 






键 名 说 A 返回 值 例子 
"seconds" | 秒 的 数字 表示 0 到 59 
"minutes” | 分 钟 的 数字 表示 0 到 59 
"hours" 小 时 的 数字 表示 0 到 23 
"mday" 月 份 中 第 几 天 的 数字 表示 1 到 31 
"wday" 星期 中 第 几 天 的 数字 0( 表 示 星 期 天 ) 到 6( 表 示 星 期 六 ) 
"mon" 月 份 的 数字 表示 1 到 12 
"year" 4 位 数字 表示 的 完整 年 份 如 1999 或 2003 
"yday" 年 中 第 儿 天 的 数字 表示 0 到 366 
"weekday" | 星期 几 的 完整 文本 表示 Sunday 到 Satuiday 
"month" 月 份 的 完整 文本 表示 January 到 December 
0 自从 UNIX 纪元 开始 至 今 的 秒 数 ， 和 timh 下 系统 相关 ， 和 典型 值 为 从 一 2147483648 到 
返回 值 及 用 于 date0 的 值 类 似 +2147483647 
4. 数学 函数 
常用 的 数学 函数 如 表 4.10 所 示 。 


例 


decbin(8) 输 出 结果 1000 
decoct(8) 输 出 结果 10 
dechex(8) 输 出 结果 8 








int bindec(string binary_string) - 进 制 数值 转 为 十 进 制 bindec(10) 输 出 结果 2 
int octdec(string octal_string) 八进制 数值 转 为 十 进 制 octdec(10) 输 出 结果 8 
int hexdec(string hex_string) 六 进 制 数值 转 为 十 进 制 | hexdec(10) 输 出 结果 16 
float round(float val [, int precision]) round(3.4) 输 出 结果 3 


float ceil(float value) 
float floor(float value) 





ceil(3.4) 输 出 结果 4 
floor(3.4) 输 出 结果 3 





float sin(float arg) 
float cos(float arg) 
float tan(float arg) 


算 该 弧度 的 sin 值 
算 该 弧度 的 cos 值 
计算 该 弧度 的 tan 值 


sin(pi0/6) 输 出 结果 0.5 
cos(pi()/6) 输 出 结果 0.866… 
tan(pi0/6) 输 出 结果 0.577… 





float log(float arg [, float base]) 
float log10(float arg) 


计算 以 e 为 底 的 对 数 
算 以 10 为 底 的 对 数 





log(10) 输 出 结果 2.302… 
log10(10) 输 出 结果 1 








void srand(int seed) 
int rand([int min, int max]) 
int getrandmax(void ) 





播 下 随机 数 发 生 器 种 子 
返回 min 到 max 之 间 的 





国 


伪 随 机 数 














返回 调用 rand() 可 能 返 








的 最 大 值 
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函 数 名 





int mt_rand([int min, int max]) 


int mt_getrandmax(void ) 











mixed max(number argl, number arg? [, 
number …]) 

mixed min(number argl, number arg? [, 
number :*:]) 

mixed min(array numbers [, array **:]) 
float pi(void ) 


number pow(number base, number exp) 


float sqrt(float arg) 





5， 与 网 络 相 关 的 函数 





功能 说 明 范例 
返回 min 到 max 之 间 的 伪 随 机 数 
返回 调用 mt_rand0 所 能 返回 的 最 大 的 随机 数 
返回 参数 中 数值 最 大 的 值 
返回 参数 中 数值 最 小 的 值 


返回 圆周 率 的 近似 值 3.1415926535898 


base 的 exp WAHRE 
"| arg 的 平方 根 








常用 的 与 网 络 相关 的 函数 如 表 4.11 ER 


表 4.11 
m 数 名 
string getenv(string varname) 
string gethostbyaddr(string ip address) 


string gethostbyname(string hostname) 
array gethostbynamel(string hostname) 


void header(string string [, bool replace [, int 


http. response. code]]) 


常用 的 与 网 络 相关 的 函数 

功能 说 明 
返回 环境 信息 
返回 指定 IP 地 址 的 主机 名 称 


返回 指定 主机 名 称 的 IP 地 址 
返 同 指定 主机 名 称 的 TP 地 址 列表 


把 HTTP 的 标 






送 给 服务 器 。string 可 以 取 Location、 
示 数 据 的 编码 方式 )、Expires( 设 定 有 效 日 期 ) 





其 中 getenv0 中 参数 及 其 含义 如 表 4.12 所 示 。 


表 4.12 getenv( ) 中 参数 及 含义 


5 A 


含 x 





http_cookie 


由 浏览 器 传 来 的 Cookie fi 








path_translated 


目前 正 被 执行 的 PHP 程序 所 在 的 完整 路 径 





query. string 


附加 在 地 址 后 面 的 字符 串 数据 





remote_addr 客户 端的 全 地址 





request mathod 


数据 传送 的 方式 ， 可 以 为 Get 或 者 post 





服务 器 的 名 称 


server name 





server protocol 


客户 端 和 服务 器 的 通信 协议 





server_software 





服务 器 端 所 使 用 服务 器 软件 ， 如 Apache. IIS 
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4.4.1 PHP 支持 的 文件 系统 
1. 文件 的 属性 


(1) 文件 名 。PHP 支持 的 文件 名 由 小 写字 母 、 数 字 、 名 点、 下划线 和 连 字符 组 成 ， 且 
以 字母 或 数字 开头 。 

PHP 支持 的 文件 名 区 分 大 小 写 ， 长 度 不 限 ， 但 尽量 简短 明了 。 

例如 ; abc.txt 与 Abc.txt 是 两 个 不 同 的 文件 。 

(2) 文件 类 型 。PHP 支持 的 文件 类 型 主要 包括 普通 文件 和 目录 ( 即 图 形 界 面 中 的 文件 
炎 )， 这 是 非常 重要 的 文件 类 型 ， 还 包括 设备 文件 、 符 号 连接 、 命 令 管 道 和 套 接 字 等 。 

(3) 文件 大 小 。PHP 支持 的 文件 大 小 以 字 节 为 单位 。 KA 

(4) 修改 时 间 。PHP 支持 的 文件 修改 时 间 指 最 后 一 次 修改 文件 的 日 期 和 时 间 。 

(5) 文件 内 容 。PHP 支持 的 文件 可 包含 的 文本 和 图 像 。 è 

(6) 文件 的 所 有 者 。PHP 支持 的 文件 所 有 者 指 创建 文件 的 用 户 ， 表现 为 一 个 相关 联 的 
用 户 账号 。 系 统管 理 员 是 拥有 root/superuser 账号 的 特殊 用 户 ， 系 统管 理 员 可 将 一 个 文件 分 
配给 不 同 的 用 户 或 定义 的 一 组 用 户 (用 户 组 六 | 

(7) 文件 的 权限 。PHP 支持 的 文件 权限 决定 用 户 对 文件 执行 的 操作 。 包 括 3 种 用 户 ， 
文件 的 所 有 者 、 组 成 员 、 其 他 用 户 。 各 有 3 种 权限 : PB WwW- 可 写 ; x- 可 执行 (对 包含 可 
执行 内 容 的 文件 )。 对 权限 的 表示 有 丙种 方式 。 

Q 3 个 三 元 组 ;分 别 表示 了 种 用 户 的 3 种 权限 < 

例如 : rwxr-xr-- -表示 所 有 者 权限 rwx; 组 成 员 权限 rx; 其 他 用 户 权限 r-o 

Q 八进制 数 : 规定 r4, w-2. x-l. .计算 对 应 三 元 组 内 各 个 可 用 权限 的 数字 总 和 。 

例如 : IWXI-Xr-- rwx 的 值 为 4+2+1=7;Fx 的 值 为 4+1=5; r-- 的 值 为 4; 权限 rwxr-xr- 对 
应 八进制 的 值 754( 为 了 区 分 其 他 进 制 ， 其 前 加 0， 即 0754)。 


2. 目录 


(1) 目录 的 结构 。PHP 支持 的 目录 以 树 或 层次 为 结构 ， 具 体内 容 如 下 。 
QD 根 目录 : 最 上 层 的 目录 。 
© TAR: 下 层 目 录 是 上 层 目录 的 子 目录 。 
© KHR: 上 层 目 录 是 下 层 目 录 的 父 目录 。 
© 当前 目录 : 任何 时 刻 ， 程 序 和 命令 解释 程序 所 关联 的 工作 目录 。 
© 特殊 子 目录 : .. 当 前 目录 本 身 的 别名 ; . 父 目 录 的 别名 。 
Q) 路 径 。PHP 支持 的 文件 路 径 分 为 绝对 路 径 和 相对 路 径 。 
O 绝对 路 径 : 从 根 目录 到 引用 文件 或 目录 所 包含 的 目录 。 
© 相对 路 径 : 从 当前 目录 到 引用 文件 或 目录 所 包含 的 目录 。 
(3) 目录 名 : 其 命名 和 使 用 方法 同文 件 。 
(4) 目录 的 权限 : 其 命名 和 使 用 方法 同文 件 。 

















PHP 动态 网 页 设计 与 制作 案例 教程 (第 = 版 ) C ») 


4.4.2 PHP 访问 文件 的 方法 


1. PHP 文件 操作 的 基本 函数 
1) 检查 文件 是 否 存在 
bool file exists (string $filename);  // $filename 指定 文件 的 路 径 和 名 称 


ÁN O akahi: 如 果 文件 存在 ， 则 返回 TRUE; 否则 ， 返 回 FALSE. 
© 网 络 中 的 共享 文件 用 //computermmame/share/filename 或 者 \computername\share\filename 来 检查 。 





示例 4-6 (说 明 : 中 文 ， HTML 中 ， 并 设 定 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 


"http://www.w3.org/TR/xhtml1/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html ; charset-utf-8" /> 
<title> 无 标题 文档 </title> : ] 
</head> 


<body> 
<?php 
$filename-'hello.txt'; . 
if(file exists($filename))print $filename. "文件 存在 ! <br>"; 
else print $filename. "文件 不 存在 ! <br>"; 





- 
</body> 
</html> 
中 没有 hello.txt 
hello.txt 文件 不 存在 ! 
2) 打开 文件 


resource fopen (string $filename, string $mode [, bool $use include path = false 
[, resource $context ]]); 


FON 画 数 的 功能 : 将 Sfilename 指定 的 名 字 资 源 绑 定 到 一 个 流 上 。 若 文件 无 法 打开 ， 则 返回 False; 
否则 ， 返 回 一 个 值 。 这 个 值 将 包含 一 个 名 为 文件 句柄 的 整数 ， 它 用 来 向 执行 文件 表示 该 文件 。 
有 时 ， 也 称 其 为 文件 指针 。 


示例 4-7 (其 中 的 PHP 代码 如 下 ， 





«?php 
$handle-fopen("l.txt","w"); // 在 hello 下 创建 文件 1.txt， 以 写 模式 创建 
fclose (Shandle) ; // 关 闭 文件 


echo('1.txt 文件 创建 成 功 ! «/br»'); 

$handle-fopen("c:/temp.txt","a"); // 打 开 C :\temp.txt， 以 追加 模式 创建 
fclose (S$handle); // 关 闭 文件 

echo "c:Ntemp.txt 文件 创建 成 功 ! "; 


m 





D 
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1.txt 文件 创建 成 功 ! 
c:\temp. txt 文件 创建 成 功 ! 


3) 读 文件 
string fread (resource $handle , int $length); // Shandle 是 fopen () 的 返 | 





El 








值 














ÁN 2 画 数 的 功能 : 从 文件 指针 Shandle 读 取 最 多 Slength 字 节 . 
© 该 函数 在 读 取 完 Slength 字 节 数 ， 或 到 达 EOF 的 时 候 ， 或 (对 于 网 络 流 ) 当 一 个 包 可 用 时 就 会 
停止 读 取 文 件 . 


mode 的 访问 模式 
mode 的 取 值 及 其 含义 如 表 4.13 所 示 。 


表 4.13 mode 的 取 值 及 其 含义 


ANE PHP 的 账号 权限 与 执行 模式 相应 时 才 有 效 、 





示例 4-8 

<?php 
$fp-fopen("1.txt","r"); // 以 读 模式 打开 文件 
$str-fread($fp,10); // 读 取 文 件 的 前 10 个 字符 
fclose ($fp); // 关 闭 文件 
echo $str."«br» <br>"; 
Sarr-file("l.txt"); // 一 次 一 行 地 读 取 整个 文件 返回 给 一 个 数组 
echo $arr[0] .$arr[1]. "<br>"; 

?» 


T.txt 的 内 容 : 
PHP is a Sript Language. 





I'm Studing it. 





运行 结果 


PHP isa S 


PHP is a Sript Language. I'm Studing it. 
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4) 文件 定位 


bool rewind (resource S$handle); 


LN 注 画 数 的 功能 : 将 Shandle 的 文件 位 置 指针 设 为 文件 流 的 开头 。 成 功 时 返回 TRUE, 或 者 在 失 
败 时 返回 FALSE. 


5) 写 文件 


int fwrite (resource $handle , string $string [, int $length ]); 





AN i£ O 函数 的 功能 : 把 $string 的 内 容 写 入 文件 指针 Shandle 处 . 如 果 指 定 了 Slength, 当 写 入 了 Slength 
字 节 或 者 写 完 了 Sstring 以 后 ， 写 入 就 会 停止 。 
O 函数 返回 写 入 的 字符 数 ， 出 现 错误 时 则 返回 FALSE, 
© 在 区 分 二 进 制 文件 和 文本 文件 的 系统 上 (如 Windows) 打开 文件 时 ，fopen() 函 数 的 mode 参 
数 要 加 上 'b'。 
图 其 他 写 文件 函数 : fputs() 是 write() 的 别名 ， 与 fwrite0 的 功 能 完全 相同 。 


Abi cH RA 


(1) string fgete (resource Shandle) 从 文件 指针 Shandle 中 读 取 一 个 字符 。 

(2) string fgets (resource Shandle [, int Slength ]) 

AkShandle 指向 的 文件 中 读 取 一 行 并 返回 长 度 最 多 为 length - 字 节 - 串 。 碰 到 换行 符 、EOF 
或 者 已 经 读 取 了 length - 1 FPE. HRE length， 则 默认 为 1 FF 

(3) array file (string Sfilename [, int Sflags = 0 [, resource Scontext ]]) 


和 readfile() 一 样 过 但 创 e() 将 文件 作为 一 个 数组 返回 -数组 中 的 每 个 单元 都 是 文件 中 相应 的 包括 
换行 符 在 内 的 一 行 < 

(4) int readfile (string $filename [, bool Suse include path = false [, resource Scontext ]]) 

读 入 一 个 诡 件 并 写 入 输出 缓冲 。 返 回 读 入 的 字 节 数 。 但 不 需要 打开 和 关闭 文件 

(5) int fpassthru (resource Shandle) 


将 给 定 的 文件 指针 从 当前 的 位 置 读 取 EOF 并 把 结果 写 到 输出 缓冲 区 ， 完 成 后 自动 关闭 文件 。 





示例 4-9 (其 中 的 PHP 代码 如 下 ， 参 看 示例 4-6) 
«?php 
$fp-fopen("l.txt","w"); // 以 写 模式 打开 文件 
$str-"I'm Studing it."; 
if(!fwrite(Sfp,Sstr))( — // 将 字符 串 写 入 打开 的 文件 
print "不 能 写 入 文件 !"; 
exit;} 
print "成 功 地 写 入 文件 !<br>"; 
fclose ($fp); // 关 闭 文件 





成 功 地 写 入 文件 ! 


Gg 
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定位 文件 函数 fseek( ) 





1. int fseek (resource Shandle , int Soffset [, int $whence = SEEK. SET ]) 
在 与 Shandle 关联 的 文件 中 设 定 文件 指针 位 置 。 新 位 置 是 以 Swhence 指定 的 位 置 加 上 $offset， 从 
文件 头 开始 以 字 节 数 度量 。Swhence 的 值 定义 如 下 : 


SEEK_SET- 设 定位 置 等 于 offset 字 节 (默认 值 )。 
SEEK_CUR- 设 定位 置 为 当前 位 置 加 上 offset. 
SEEK_END- 设 定位 置 为 文件 尾 加 上 offset. 

2. int ftell (resource Shandle) 

返回 由 $handle 指定 的 文件 指针 的 位 置 ， 也 就 是 文件 流 中 的 偏 移 量 .。 


6) 关闭 文件 


\ 
bool fclose (resource $handle); ^ SONS 





FINGER O mihi: 将 Shandle 指向 的 文件 关闭 . RRA RR S) TRUE; 如 果 失 败 ， 则 返回 FALSE。 
Q) 文件 指针 必须 有 效 ， 并 且 是 通过 fopen( ) 或 fsbckopen( ) 成 功 打 开 的 。 
图 没有 此 函数 ， 会 在 脚本 结束 时 自动 美 闭 打开 的 文件 . 
@ 关闭 文件 的 目的 是 释放 打开 文件 时 所 占用 的 资源 。 
7) 复制 文件 


bool copy (string $source , String $dest [, resource $context ]); 


FAN GRO 将 文件 从 $souite 复制 到 Sdest， 如 果 成 功 、 则 返回 TRUE; 如 果 失败 ， 则 返回 FALSE。 
@ PHP 必须 拥有 对 副本 所 在 目录 的 访问 权限 知 则 无 法 创建 到 本. 
© XB eA, VERAS 





天 例 4-10 (其 中 的 PHP 代码 如 下 ， 人 参看 示例 4-6) 
«?php 
if(!copy("l.txt","temp.txt"))  // 将 1.txt 复制 temp .txt 
print "文件 复制 失败 ! «br /»"; 
else 


print "文件 复制 成 功 ! «br /»"; 





文件 复制 成 功 ! 
8) 重 命 名 文件 


bool rename (string $oldname , string $newname [, resource $context ]); 


FANE O 画 数 的 功能 : 尝试 把 Soldname 重 命名 为 Snewname. 成 功 时 返回 TRUE, 失败 时 返回 FALSE, 


Q) PHP 必须 拥有 对 重 命名 文件 所 在 目录 的 访问 权限 ， 和 否则 无 法 重 命名 文件 。 


加 如 果 重 命名 的 文件 已 存在 ， 那 么 rename( ) 函 数 将 履 盖 它 。 
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9) 删除 文件 


bool unlink (string $filename [, resource $context ]); 


AN (D 函数 的 功能 : 删除 $filename。 和 UNIX、C 的 unlink( ) 函 数 相 似 。 成功 时 返回 TRUE, 
@ 在 Windows 系统 上 可 能 无 法 正常 工作 . 
© 删除 文件 后 无 法 恢复 。 


2， 其 他 函数 
(1) 获取 文件 的 属性 如 表 4.14 Bros o 
表 4.14 获取 文件 的 属性 


函数 LEE; 
int fileatime (string Sfilename) 以 UNIX IH [80800 77 OE [PLC PG E CU REIN 
int filectime (string $filename) 取得 文件 信息 节点 (info node,innode) 上 次 修改 时 间 (UNIX 时 间 戳 ) 
int filegroup (string $filename) 取得 该 文件 所 属 组 的 ID 
int filemtime (string Sfilename) 取得 文件 上 次 被 修改 的 时 间 (UNIX MERR) 
int fileowner (string Sfilename) 返回 文件 的 数字 用 户 TD 
int fileperms (string Sfilename) 返回 文件 的 权限 
int filesize (string Sfilename) 返回 文件 的 类 小 ， 以 字 节 为 单位 
string filetype (string $filename) 返回 文件 的 类 型 : fifo、char、block、link、file、unknown 
bool is file (string $filename) 判断 给 定 文件 名 是 否 为 一 个 正常 的 文件 





bool is readable (string $filename) | 判断 给 定 文件 名 是 否 可 读 
bool is_writable (string $filename) | 判断 给 定 的 文件 名 是 否 辣 写 
bool is_dir (string $filename) 判断 给 定 文件 名 是 否 是 一 个 目录 
(2) 更 改 文件 权限 。 
bool chmod (string $filename , int $mode); 
ÁN 函数 的 功能 : 尝试 将 $filename 所 指定 文件 的 模式 改 成 Smode 所 给 定 的 。 
(3) 更 改 文件 所 有 权 。 
bool chown (string $filename , mixed $user); 
LN (D 运行 PHP 的 用 户 账号 必须 拥有 这 个 文件 ， 且 是 指定 组 的 成 员 ， 一 般 使 用 root 账号 。 
© 函数 的 功能 : 尝试 将 文件 $filename 的 所 有 者 改 成 用 户 Suser( 由 用 户 名 或 用 户 ID JE). 只 有 
超级 用 户 可 以 改变 文件 的 所 有 者 。 
© 更 改 文 件 所 有 权 是 一 种 很 少 使 用 的 不 安全 的 方法 。 
(4) 锁定 文件 。 
bool flock (resource $handle , int Soperation [, int &$wouldblock ]); 
FIN RD EH oh le: 以 咨询 方式 (也 就 是 说 所 有 访问 程序 必须 使 用 同一 方式 锁定 ， 否 则 它 不 会 工作 ) 
锁定 全 部 文件 ， 成 功 时 返回 TRUE， 失败 时 返回 FALSE. 
@ Shandle 必须 是 一 个 已 经 打开 的 文件 指针 。S$operation 可 以 是 以 下 值 之 一 : 


do 
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LOCK SH ”取得 共享 锁定 ( 读 取 程 序 )。 多 个 能 持 有 ， 其 他 等 待 直到 获得 为 止 。 
LOCK EX ”取得 独占 锁定 ( 写 入 程序 )。 只 有 一 个 持 有 ， 其 他 等 待 直到 获得 。 
LOCK SH-LOCK NB ”获得 指定 文件 的 共享 锁 。 不 希望 flock( ) 在 锁定 时 堵塞 。 
LOCK EX-LOCK NB ”获得 指定 文件 的 独占 锁 。 不 希望 flock( ) 在 锁定 时 堵塞 。 
LOCK_UN 释放 锁定 (无 论 共享 或 独占 )。 


44.3 PHP 访问 目录 
1. 读 取 目 录 的 内 容 





resource opendir (string $path [, resource $context]); 
string readdir ([resource $dir handle]); 
void closedir ([resource $dir handle]); 


ÁN O opendir( Jk I —/4 A Rá, ZMA closedir(), readdir( )fe rewinddir( ) 调 用 中 。 
Q) readdir( ) 返 回 目 录 中 下 一 个 文件 的 文件 名 。 文件 名 以 在 文件 系统 中 的 排序 返回 。 
图 closedir( ) 关 闭 由 $dir_handle 指定 的 目录 流 。 释放 opendir( ) 分 配 的 资源 


«?php 
$dire'.'; 
$i-0; 
if(Gis dir($dir))( z // 检 测 是 否 一 个 合法 目录 
if ($df-Gopendir ($dir))( // 打 开 目 录 
while ($file=@readdir ($df)){ // 读 取 目 录 
$i++; 
echo "$i:$file <br>"; V/ 输 出 目录 中 的 内 容 
) // while : 
closedir($df); : // 关 闭 目录 
IAM ME 
) //if 





2. 创建 目录 


bool mkdir (string $pathname [, int $mode]) 


ÁN 2 akani: 尝试 新 建 一 个 由 Spathname 指定 的 目录 。 
3. 删除 目录 
bool rmdir (string $dirname) 


LN 注 函数 的 功能 : 删除 Sdimname 所 指定 的 目录 . 该 目录 必须 是 空 的 ， 且 对 该 目录 要 有 相应 的 权限 。 
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4. 获取 和 更 改 工作 目录 


string getcwd (void ); 
bool chdir (string $directory); 


LO 法 getcwd() 返 回 一 个 包含 当前 工作 目录 的 字符 囊 。 
chdir( ) 将 PHP 的 当前 目录 改 为 Sdirectory. 
5. 处 理 路 径 





string dirname (string $path); 
string basename (string $path [, string $suffix]); 
mixed pathinfo (string $path); 


Nė dimame0 返 回 一 个 包含 指向 一 个 文件 的 全 路 径 的 字符 事 (去 掉 文 件 名 后 的 目录 名 ). 
basename() 返 回 一 个 包含 指向 一 个 文件 的 全 路 径 的 字符 串 ,* 本 函数 返回 基本 的 文件 名 。 
pathinfo() 返 回 一 个 包含 Spath 信息 的 关联 数组 。 包 括 以 下 的 数组 单元 : dirname( 路 径 的 目录 部 
分 )、basename( 路 径 的 文件 部 分 ) 和 extension( X RE). 





示例 4-12 (其 中 的 PHP 代码 如 下 ， 
<?php TE 
$path= fone /heepa /nen indes. Phe" E // 指 定 路 径 给 变量 





$file-basename ($path) // 获 取 的 是 文件 
$dir-dirname ($path) ; /7 获取 的 是 目录 
$path_parts=pathinfo (Spath); E X /7 读 取 文件 目录 信息 
echo "basename(): $dir«br»"; NS) 7/ 输出 目录 

echo "dirname():$file «br»"; dn EL 4: 


echo "pathinfo() 目录 部 分 : M -Spath parts['dirname' 1 em 
echo "pathinfo () 文件 部 分 : i .Spath parts['basename' ]."4br»"; 
echo "pathinfo (扩展 名 : m .$path parts[' extension']."«br»"; 
R> 
a | 
basename () : /home/httpd/html 
dirname () :index.php 
pathinfo () 目录 部 分 : /home/httpd/html 
pathinfo () 文 件 部 分 ， index.php 
pathinfo (H H: php 


45 文件 管理 器 


C 


本 节 案 例 实 现 了 一 个 简易 文件 管理 器 ， 能 查看 当前 目录 下 的 文件 名 、 文 件 类 型 和 大 小 、 
创建 日 期 和 修改 日 期 ; 可 以 通过 查看 上 一 级 目录 和 下 一 级 目录 浏览 所 有 文件 ; 可 以 查看 PHP 


Gy 
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和 TXT 文本 文件 内 容 。 
文件 管理 器 的 界面 效果 如 图 4.8 和 图 4.9 所 示 。 
文件 管理 器 





当前 目录 : Diwampwwwiextend'ch4 
文件 名 大 小 创建 时 间 最 后 修改 时 间 
目录 — 2016/02/09 07:35:50pm. 2016/02/09 09:50:35pm 

A 目录 — [|2016/02/09 07:34:28pm [2016/02/09 07: 
file viewer.php RKB  |D016/02/09 07:36:34pm 2016/02/09 09: 
(show filephp p79B |2016/02/09 07:37:32pm [2016/02/09 07: 


































































































图 4.8 文件 管理 器 的 主 界面 


f 含 链 接 的 目录 名 时 打开 相应 的 目录 ， 进 入 相应 的 文件 管理 器 界面 ; 
:名 时 进入 如 图 4.9 所 示 的 文件 查看 器 的 界面 。 


< 文件 查看 器 












接 的 文 


: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona/EN" 
: "http://www. w3.org/TR/xhtml /DTD/xhtmll -transitional.did"-- 
: <html xmins="http://vww.w3.org/1999/xhtml"> 


1" width=" 10096» 
<tr align="center" bgcolcr-"yellow"» 
<th> 文 件 名 </th><th> 失 才 <th> 创 建 时 间 </th><th> 最 后 终 改 时 间 </th>< 
Line #12 : <?php 
Line #13 : if(lisset(S_GE Ff'ctrrentdir’))|lempty($_GET['currentdir)} 
Line #14 : Sdir=getewdQ; 


图 4.9 文件 管理 器 的 文件 查看 器 界面 





V PHpj ia 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«head» 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /» 
<title> 文 件 管理 器 </title> 
</head> 
<body> 
<h3> 文 件 管理 器 </h3> 
«table border-"1" width="100%"> 





«tr align="center" bgcolor-"yellow"» 
<th> 文 件 名 </th><th> 大 小 </th><th> 创 建 时 间 </th><th> 最 后 修改 时 间 </th></tr> 
<?php 
if(!isset($ GET['currentdir'])||empty($ GET['currentdir'])) 
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$dir-getcwd(); 
else 

$dir=$ GET['currentdir']; 
chdir ($dir); 
$currentdir-getcwd(); 
echo "当前 目录 : ".getcwd()."«br»"; 
$dh=opendir ($dir); 
while ($item=readdir ($dh)){ 

echo "«tr»«td»"; 

if (is_dir ($item) ){ 








if ($item= fede ieu 
elseif(Sitem—"..")( 
$currentdir-getcwd()."NN.."; 





echo "<a href-".$ SERVER['PHP SELF']."?currentdir-".$currentdir."».. 
</a>"; 


} 


else{ 
$currentdir=getcwd () ."\\$item"; 
echo "<a href=".$ SERVER['PHP SELF']."?currentdir=".$currentdir.">" 


.Sitem."«/a»"; 
) 
) 


else( 
Sextname-substr ($item, strrpos ($item,".")); 
if(strtoupper ($extname)--".PHP"||strtoupper (S$extname) --".TXT") ( 


S$currentdir-getcwd(); 
echo "<a href-./show file.php?currentdir 
"&filename-".$item."&type- " . Sextname."»".$item."«/a»"; 
) 


else echo "$item«/td»"; 


$currentdir. 





) 
$file size-filesize($item)." 
if(is dir(Sitem)) $file size 





else if(filesize(Sitem)»1024) 

$file size-round(filesize(Sitem)/ 1024)."KB"; 

echo "«td»$file size«/td»"; 
date default timezone set ("Asia/Shanghai"); 

$create date-date("Y/m/d h:i:sa",filectime ($item)); 
echo "«td»$create date«/td»"; 

$update date-date ("Y/m/d h:i:sa",filemtime (S$item)); 
echo "«td»$update date«/td»«/tr»"; 








} 
closedir ($dh); 
?» 
</table> 
</body> 
</html> 
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(3) 把 文档 以 file viewer.php 为 文件 名 保存 在 extend\ch4 文件 夹 下 。 

(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
<<!-- 文 件 查看 器 ，show_file.pPhp--> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 


"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 


<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 





<meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<title> 文 件 查看 器 </title> 
</head> 
<body> 
«a href="./file_viewer.php"> 文 件 查 看 器 </a><br /><br /> 
<?php 
$currentdir=$ GET['currentdir']; 
$filename=$ GET['filename']; 
$type=$ GET['type']; 
if (strtoupper ($type)==".PHP") { 
$lines = file ($currentdir,"\\".$filename); 
foreach ($lines as $line num => $line) 
echo "Line $«b»(Sline num}</b> : " 





" . htmispecialchars ($line) . "«br» An"; 
) 
else( 
$fp=fopen (Scurrentdir."NNV".Sfilename, "r"); 
while ($line-fgets($fp))( 
$line-htmlentities ($1ine,ENT COMPAT,"utf-8"); 
echo $line.'«br/»'; 
) 
fclose ($fp); 
) 
7> 
</body> 
</html> 


(6) 把 文档 以 show_file.php 为 文件 名 保存 在 extend\ch4 文件 夹 下 。 


e 
LEPTTT, 


通过 学 习 本 章 案例 ， 对 PHP 的 函数 和 文件 系统 有 所 认识 ， 主 要 包括 以 下 / 
(1) PHP 的 函数 分 为 自 定 义 函 数 和 系统 内 置 函 数 。PHP 自 定义 函数 遵循 语 
PHP 的 系统 内 置 函 数 以 库 的 方式 组 织 ， 常 用 函数 库 可 以 直接 使 用 ， 有 些 
要 加 载 并 激活 才能 使 用 。 

(2) PHP 的 文件 系统 也 是 通过 一 组 内 置 函 数 来 实现 的 。 在 函数 库 中 对 应 文件 函数 库 和 
目录 函数 库 ， 都 是 默认 支持 的 。 

(3) 网 站 计数 器 和 文件 管理 器 中 都 使 用 了 文件 管理 数据 。 








法 规范 ， 而 
常用 的 函数 库 需 
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£à 恩 考 练习 


(1) 当 多 个 用 户 可 以 同时 访问 一 个 单独 的 PHP 脚本 时 ， 必 须 使 用 什么 操作 ? 为 什么 ? 
(2) 如 何 表示 “只 为 所 有 者 提供 读 权限 ， 而 不 为 其 他 用 户 提供 任何 权限 ”的 文件 权限 ? 
(3) 分 析 在 PHP 中 使 用 文件 存储 数据 的 优势 和 局 限 。 
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项 目 4-1 页 面 单 击 计数 器 





a) 演示 如 何 使 用 PHP 读 和 写 文件 。 X% 
(2) 显示 如 何 创建 一 个 Web 页 面 计数 器 。 SS 


步骤 : 
(D 创建 以 下 的 PHP 脚本 ， 将 其 保存 在 文件 Jo 中 ， 然 后 上 载 到 服务 器 上 的 
www/exercise/ch4 rf: RN | 





(2) 创建 以 下 的 PHP 脚本 ， 将 其 保存 在 文件 ctr_testphp 中 ， 然 后 将 其 上 载 到 服务 器 上 


的 www/exercise/ch4 P: 
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(3) 在 包含 所 上 载 脚本 的 同一 个 目录 中 创建 文件 ctr. test.php.dat, 确保 PHP 拥有 对 文件 
的 读 和 写 权限 。 

(4) 研究 ctrphp 文件 。 

CD 如 何 使 用 PHP 变量 $_SERVER['PHP_SELF'] 来 确定 包含 它 的 文件 的 名 称 ， 然 后 添 
加 .dat， 组 成 包含 页 面 计数 器 的 文件 的 名 称 。 

© 用 来 操作 文件 的 函数 。 

(5) 研究 ctr_test.php 文件 。 

(D 主要 组 成 元 素 。 

@ 文件 中 倒数 第 三 行 PHP 脚本 的 作用 。 

(6) 在 Web 浏览 器 上 浏览 这 段 代码 的 执行 结果 单 击 访问 页 面 的 次 数 ， 刷 新 页 面 后 的 
结果 (屏幕 截图 表示 )。 





















































项 目 4-2 改进 的 页 面 单 击 计数 器 


项 目 目标 : 

(1) 演示 如 何 锁定 文件 。 

(2) 显示 如 何 实现 更 可 靠 的 Web 页 面 计数 器 。 
FR: 

(1) 创建 以 下 的 PHP 脚本 ， 将 其 保存 在 文件 Ictrphp H 然后 将 其 上 载 到 服务 器 上 的 


www/exercise/ch4 P: 

<?php x 5 WM 
5 ($ SERVER['PHP SELE']). l dat"; 

$fh- efopen ($c£ile," "r£U) or die ("«BR»Failed to open file «I»$cfile </I>."); 
&flock(Sfh, , LOCK | EX) or die ("<BR>Failed to lock file <I>$cfile</I>."); 
$count=fgets ($fh, 6); 

$count=$count+1; 

$count-str pad($count,6); 

Grewind(Sfh) or die("«BR»Failed to rewind file «I»$cfile«/I»."); 

if (@fwrite ($fh,$count)---1) 

die("«BR»Failed to write to file <I>$cfile «/I»."); 

echo "$count"; 

Gflock($fh,LOCK UN) or die ("<BR>Failed to unlock file «I»$cfile«/I»."); 
fclose($fh) or die("«BR»Failed to close file «I»$cfile«/I»."); 


?» 
(2) 创建 以 下 的 PHP 脚本 ,将 其 放 在 一 个 名 为 lctr_test.php 的 文件 中 ， 然 后 将 其 上 载 到 
服务 器 上 的 www/exercise/ch4 rf: 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
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«title»PHP 页面 单 击 计 数 器 < 人 title> 
</head> 
<body> 
This page has been accessed <B><?php include ("lctr.php"); ?></B> times. 
</body> 
</html> 


(3) 在 包含 所 上 载 脚本 的 同一 个 目录 中 创建 文件 letr_testphp.dat， 确 保 PHP 拥有 对 文 
件 的 读 和 写 权 限 。 

(4) 研究 letrphp 文件 。 

CD 如 何 使 用 PHP 变量 $_SERVER['PHP_SELF'] 来 确定 包含 它 的 文件 的 名 称 ， 然 后 添 
加 .dat， 组 成 包含 页 面 计数 器 的 文件 的 名 称 。 

@ 用 来 操作 文件 的 函数 。 

图 如 何 实现 文件 锁定 和 解锁 。 

(5) 研究 letr. test.php 文件 。 

(D 主要 组 成 元 素 。 

© 文件 中 倒数 第 三 行 PHP 脚本 的 作用 。 

(6) 在 Web 浏览 器 上 浏览 这 段 代码 的 执行 结果 ; 单 击 访问 页 面 的 次 数 ， 刷 新 页 面 后 的 





























结果 (屏幕 截图 表示 )。 
(7) 将 两 个 Web 浏览 器 指向 脚本 的 URE。 尝 试 使 这 两 个 浏览 器 同时 访问 该 页 面 ， 观 察 
计数 器 的 变化 。 


项 目 4-3 通信 簿 浏览 器 


项 目 目 标 : 4 
(1) 演示 如 何 浏览 文件 。 
(2) 演示 如 何 使 用 PHP 建立 与 表单 控件 相关 的 VALUE 属性 。 
步骤 : 
(1) 创建 以 下 的 PHP 脚本 ， 将 其 保存 在 文件 browserphp 中 ， 然 后 上 载 到 PHP 服务 器 
/exercise/ch4/ 上 : 


«!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<head> «title»PHP 通信 德 浏览 器 </title> </head> 
<body> 
<H2> 通 信 短 浏览 器 </H2> 
<form action-"browser.php" method="POST"> 
«?php 
$msg-""; 
Sooffset-0; 
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(2) 将 下 面 的 文本 文件 上 载 到 服务 器 中 ， 将 其 命名 为 abook.txt， 放 在 与 文件 browser .php 
相同 的 文件 夹 /exercise/ch4/ 中 (这 个 文件 的 每 一 行 都 应 该 是 48 个 字符 , 电子 邮件 的 地 址 应 该 
在 25 列 ， 考 虑 到 字符 集 对 网 页 中 文 显示 的 问题 ，abook.txt 要 使 用 utf-8 字符 集 ， 文 件 建 好 
后 ， 使 用 该 程序 的 添加 功能 把 下 面 的 数据 依次 添加 进去 )。 







(3) 研究 browserphp 文件 。 
© 使 用 $offset 来 跟踪 当前 浏览 





@ 如 何 使 用 PHP 建立 名 为 email 属性 。 
© PHP 拥有 对 文件 ELA o 0s 
(4) 在 Web Poz 代码 的 执行 结果 幕 截图 表示 并 予以 说 明 )。 
号 r 
Es Ae A 
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会 员 注 册 和 管理 设计 与 数据 获取 


通过 本 章 的 学 习 ， 能 够 使 读者 : 

(1) 理解 PHP 数据 获取 的 常用 方法 。 

(2) 掌握 在 PHP 中 使 用 表单 获取 数据 的 方法 。 

(3) 掌握 在 PHP 中 使 用 预定 义 变量 的 方法 ; 

(4) 掌握 在 PHP 中 使 用 cookie 和 session 的 方法 。 


本 章 为 读者 准备 了 以 下 学 习 资 源 : 

(1) 示范 案例 :- 展示 “会 员 注册 ”和 “会 员 管理 ”的 设计 与 实现 过 程 ， 分 别 对 应 本 章 
的 5.1~5.2 节 和 $.3=5:4 节 。 案 例 代码 存 放 在 文件 夹 “ 教 学 资源 \wuyavchsvegister” 和 “教学 
资源 \wuya\ch5\memiber” 中 ,数据 库 数据 存放 在 文件 夹 “ 教 学 资源 \wuya\ch5\dataimember” 中 。 

(2) 技术 要 点 : 描述 “PHP 的 数据 获取 ” 对 应 本 章 的 5.5~5.6 节 。 

(3) 实践 项 目 : 代码 存放 在 文件 夹 “ 教 学 资源 \exercise\ch5\” 中 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 

(1) 解读 示范 案例 的 分 析 和 设计 。 

(2) 模仿 练习 : 选择 一 个 PHP 集成 开发 工具 ， 如 Dreamweaver， 按 照 实 现 步骤 重 现 案例 。 

(3) 扩展 练习 : 按 实践 项 目的 要 求 ， 先 明确 项 目 目标 ， 再 在 PHP 集成 开发 环境 中 实现 
项 目 代 码 ， 接 着 对 代码 中 的 PHP 语言 要 素 进 行 分 析 ， 提 升 理 解 和 应 用 能 

学 习 过 程 中 ,提倡 结对 或 3 人 组 成 学 习 小 组 ， 一 起 探讨 和 研究 会 员 注册 和 管理 的 设计 ， 
但 对 PHP 数据 获取 的 学 习 和 具体 项 目的 实现 还 是 鼓励 能 独立 完成 。 








CO asa enorme 
o Ee n 
E 


本 章 案 例 介 绍 如 何 设 计 和 实现 会 员 注册 和 管理 模块 ， 对 应 主页 中 的 注册 和 会 员 管理 链 
接 ， 其 中 涉及 PHP 表单 数据 处 理 、 预 定义 变量 和 会 话 管理 等 常见 的 几 种 数据 获取 方法 。 








5.1 会 员 注册 和 管理 概述 


一 些 需要 付费 的 网 站 或 个 人 网 站 都 采用 了 会 员 制 对 访客 进行 管理 。 这 不 仅 能 避免 误 间 
的 用 户 及 别有用心 的 黑客 ， 还 能 方便 管理 员 对 访客 的 有 效 管理 。 
本 书 案例 中 的 网 上 书店 ， 对 客户 进行 了 分 级 管理 ， 包 括 3 种 用 户 ， 一 是 新 用 户 ， 需 要 
注册 才能 成 为 会 员 ， 二 是 会 员 用 户 ， 可 能 需要 修改 资料 和 找 回 遗忘 的 密码 ， 三 是 管理 员 用 
户 ， 承 担 对 会 员 资料 的 维护 和 更 新 。 
为 了 方便 新 用 户 ， (CEDERE T EIL "SERI" S, EA UTERE 
也 能 注册 。 在 “注册 ”链接 中 ， 要 求 用 户 输入 相关 的 个 人 资料 和 申请 购书 卡 信息 ，PHP f 
序 获取 用 户 的 输入 信息 并 做 出 相应 的 处 理 后 写 入 数据 库 。 
对 于 会 员 用 户 ， 先 要 求 验证 身份 ， 再 根据 用 户 的 输入 信息 ， 读 取 数 据 库 中 的 相关 信息 
给 出 个 人 资料 以 便 修改 或 找 回 遗 忘 的 密码 》 
对 于 管理 员 用 户 ， 可 以 查看 所 有 会 负 由 户 的 个 人 资料 。 
购书 卡 是 购书 付费 的 一 种 方式 。 对 用 户 购书 优惠 提供 分 级 管理 ， 如 根据 购书 卡 的 金额 ， 
分 为 普通 卡 、 银 卡 、 金 卡 和 咎 五 盯 ， 以 此 享受 优惠 折扣 
日 户 通 过 表单 输入 资料 ,- PHP 获取 表单 数据 7 写 入 数据 库 。 
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5.2.4. 系统 架构 
新 会 员 “ 注 册 ” 模 块 的 工作 流程 如 图 5.1 所 示 。 
请 求 登 录 
一 
新 会 员 Web 服 务 器 


提取 购书 卡 信息 
验证 有 效 性 







合法 验证 后 
写 入 会 员 信 息 


图 5.1 新 会 员 “ 注 册 ” 模 块 的 工作 流程 


qe 
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O 会 员 向 服务 器 发 出 登录 请 求 。 

© 服务 器 根据 请 求 向 会 员 传送 欢迎 页 面 ， 并 提供 选择 的 入 口 . 

© 会 员 进 入 身份 验证 ， 读 取 数 据 库 中 的 数据 并 与 输入 的 数据 比较 。 
图 新 会 员 注 册 成 为 会 员 ， 填 写 新 会 员 资 料 信息 或 申请 购物 卡 . 


P 


会 员 管理 ”模块 的 工作 流程 如 图 5.2 所 示 。 


请 求 URL FE 
O- ry Li 

会 员 管理 页 面 El 
用 户 Web 服 务 器 
注册 为 新 会 员 普通 会 员 管理 J 管理 员 页 面 

写 入 J 人 提取 
saanman SA 


数据 库 


“ 





















写 入 用 户 信息 


图 5.2 “会 员 管理 ”模块 的 工作 流程 
Laun 


O 用 户 向 服务 器 发 出 访问 请 求 。 

D 服务 器 以 菜单 方式 提供 的 会 册 管 理 页 面 供用 户 选择 。 

O 新 用 户 注册 为 会 员 ， 提 供 输 入 信息 的 表单 并 要 求 用 户 验 入 简 关 信息 ， 写 入 数据 库 ， 

O 普通 会 员 能 登录 到 会 员 专区 ， 通 过 用 户 的 会 员 号 和 密码 验证 身份 进入 专区 ;通过 电子 邮箱 和 住 
址 来 提取 忘记 的 密码 ;通过 用 户 的 会 员 号 和 密码 验证 身 痊 进 入 修改 个 人 资料 页 面 . 

© 管理 员 作为 岗 站 的 站 长 ， 也 是 通过 用 户 前 会 员 芝 和 密码 验证 身份 进入 其 管理 界面 ， 浏 览 会 员 次 
HEMRA RH! 
522 ”系统 设计 

1， 逻 辑 结构 设计 


根据 对 新 会 员 “ 注 册 ” 模 块 系统 架构 的 描述 ， 可 得 其 逻辑 结构 ， 如 图 5.3 所 示 。 














有 效 性 验 让 login.php 
注册 页 面 regindex.html A AZAR 
会 员 的 有 效 性 


表单 : 会 员 以 会 员 密 码 等 













注册 购书 卡 applycard.php 
表单 : 新 会 员 屿 /购书 卡 等 






有 效 性 验 让 apply.php 


购书 卡 的 有 效 性 


成 功 注 册 success.php 
写 入 数据 库 
In uc DA CUI NET 







注册 个 人 资料 apply.src.php 
表单 : 用 户 个 人 资料 
53 ”新 会 员 “ 注 册 ” 模 块 的 逻辑 结构 
根据 对 “会 员 管理 ”模块 系统 架构 的 描述 ， 可 得 其 逻辑 结构 ， 如 图 5.4 所 示 。 

















主页 面 memindex.php 


链接 菜单 选择 
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jr zx fAapplysrc.php 





会 员 痘 录 losgin.php 


表单 : 身份 验 让 





添加 购书 卡 
addcard.php 





1 


1 i 




















dic 修改 个 人 资料 购书 卡 专区 会 员 
forget.php modify.php usercard.php manager.php 
查询 按钮 读 取 数据 库 读 取 数 据 库 读 取 数据 库 读 写 数据 库 





updateusrc.php card. c T updatecard.php 


2. 数据库 设计 


在 MySQL 数据 库 服 务 器 上 建立 名 为 member 的 数据 库 ， 其 中 包含 4 个 数据 表 ， 分 别 为 
userinfo, administer, usercard 和 card， 各 字段 的 定义 和 说 明 如 表 $.1 一 表 5.4 所 示 。 


"T 购书 卡 充值 











与 数据 库 





图 5.4 “会 员 管 理 ”模块 的 逻辑 结构 


表 5.1 数据 表 userinfo 









































* R 类 m & 注 
serial int(5) auto increment 主键 
userid char(30) 位 数 4 一 30, 必须 由 字母 与 数字 组 成 
username char(20) 
password char(20) 6 一 10 PERRERA 
email Char(50) 电子 邮箱 
addr char(50) 地 址 
post char(30) 邮编 
phone char(20) 电话 号 码 
createtime datetime i 料 创建 时 间 CURRENT_TIMESTAMP 

表 5.2 数据 表 administer 

字 R 类 型 说 明 备 i 
serial int(5) 员 序 列 号 auto_increment 主键 
userid char(30) 登录 的 会 员 号 位 数 4 一 30, 必须 由 字母 与 数字 组 成 
username char(20) 管理 员 姓 名 
password char(20) 管理 员 登 录 密码 6 一 10 个 字母 或 数字 的 组 合 
IP char(20) 管理 员 IP 地 址 可 远程 获取 
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表 5.3 数据 表 usercard 











说 明 & 注 














serial int(5) 会 员 持 购书 卡 的 卡 序列 号 ”| auto increment 主键 
userid varchar(30) 会 员 登 录 的 会 员 号 
cardno varchar(20) 








password varchar(30) 

























类 & x 
serial int(5) 购书 卡 序列 号 auto_increment 主键 
cardno char(20) | 否 购书 卡 编号 
cardpsd char(20) 购书 卡 密码 








卡 中 所 剩余 额 
购书 卡 的 等 级 
购书 卡 状态 
购书 卡 创建 时 间 











float 





balance 










普通 卡 / 银 卡 / 金 卡 /钻石 卡 
Y( 可 以 被 申请 ) 
CURRENT_TIMESTAMP 





char(8) 
char(2) 


cardlevel 





cardstatus 





datetime 











ÉIN 注 通过 phpMyadmin 创建 上 述 数据 库 表 并 输入 相关 数据 。 在 MySQL 的 data 文件 夹 中 会 自动 创建 


以 此 数据 库 为 名 的 文件 夹 。 
对 于 数据 表 card， 插 入 平 列 数据 ， 作 为 测试 数据 ”如 表 5.5 所 示 。 
表 5.5 数据 表 card 的 测试 数据 


62853966 333333 | 100 [henk 
500 : 









cardstatus 































2 62852966 2222 
3 | 62851966 uii 1000 
4 62850966 000000 10000 


另外 ， 其 他 表 中 的 数据 ， 将 在 测试 时 产生 。 


3. 界面 设计 


(1) 注册 模块 。 
© 用 户 登录 regindex.php 的 页 面 规划 如 下 。 其 中 的 样式 定义 在 register.css 中 。 











Logo: 180x50 Banner: 600x50 
空白 : 780x5 
空白 : 780x10 标题 栏 








请 输入 用 户 的 会 员 号 ”单行 文本 表单 
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( 续 ) 
请 输入 密码 ”单行 文本 表单 
登录 按钮 
处 理 后 反馈 信息 
注册 提示 信息 
版 权 信息 








© 购书 卡 信息 applycard.php 和 新 用 户 个 人 资料 applysrc.php 的 页 面 规划 如 下 。 
Logo: 180x50 


Banner: 600x50 
空白 : 780x5 
当前 状态 信息 栏 ，780x50 
空白 : 780x5 

















提示 信 





单行 文本 表单 





提交 按钮 表单 











处 理 后 反馈 信息 
版 权 信 
员 管理 模块 。 
© 主页 memindex.php 的 页 面 规划 如 下 。 其 中 的 样式 定义 在 member.css 中 。 
Logo: 180x50 Banner: 600x50 
空白 ;780x10 





*. 780x50 
空白 ，780x5 





Q) 登录 login.php 的 页 面 规划 如 下 。 
Logo: 180x50 Banner: 600x50 
"fq: 780x10 











". 780x50 





空白 : 780x5 





标题 栏 
输入 提示 信息 ”单行 文本 表单 
是 交 按钮 表单 
处 理 后 反馈 信息 
版 权 信 息 




















© 修改 个 人 资料 modify.php 的 页 面 规划 类 似 applysrcphp， 不 同 之 处 在 于 表单 内 显示 
了 用 户 的 原始 信息 。 





© 忘记 密码 forget.php 的 页 面 规划 同 登录 login.php。 其 他 页 面 规划 类 似 登录 login.php。 
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5.8 ”注册 模块 的 实现 





找 相关 的 文件 。 





根 文件 夹 已 建立 文件 夹 register 作为 存放 与 注 
(2) 确认 在 register 文件 夹 中 建立 文件 夹 css 和 文件 夹 images。 

(3) 在 Ulead GIF Animator 中 制作 注册 的 banner, LA login.gif 保存 在 文件 夹 images 中 。 
(4) 把 图 像 文 件 logo.gif 也 保存 在 文件 夹 images 中 。 


5.3.1 页 面 样式 表 





y 
A CSS 编 码 
代码 文件 ，register.css 


(1) 启动 Dreamweaver， 新 建 CSS 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 输入 如 下 代码 


Gcharset "utf-8"; 

/* CSS Document */ 

tapp { /* 定 义 整个 页 面 的 样式 */ 
width: 780px; 
margin: 0 auto; 

l 

#top { ”/* 定 义 顶 部 样式 */ 
height: 60px; 
width: 780px; 

} 

#bt {  /* 定 义 标题 样式 */ 
font-size: 24px; 
font-weight: bold; 
color: #399; 
height:40px; 
background-color: #FFC; 
vertical-align: middle; 
text-align: center; 
padding-top: 10px; 
padding-bottom: 10px; 

} 

#bd { ”/* 定 义 表单 样式 */ 
font-size: 14px; 
color: #F60; 
background-color: #FFC; 
padding-top: 10px; 
margin-bottom:2px; 
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terr {  /* 定 义 反馈 信息 栏 样 式 */ 
height: 20px; 
font-size: 14px; 
color: #099; 
background-color: #FFEFCE; 
padding: 10px; 


margin-top: 2px; 


#ts{ ”/* 定 义 提示 信息 栏 样式 */ 
height: 30px; 
font-size: 14px; 
color: #099; 
background-color: #FCC; 
padding: 10px; 
) 
*copyright ( /* 定 义 底部 版 权 信息 样式 */ 
padding-top: 2px; 
height: 60p. 


text-align: center; 





font-size: 14px; 
line-height: 150$; 
) 
table ( 
margin: 0px; 
padding: 0px; 
width: 780px; 
) 
form ( 
margin: 0px; 


padding: 0px; 


a:link (color: #399;} 
a:visited (color: $906;) 
a:hover (color: #F90;} 


a:active {color: #099;} 


width: 780px; 
line-height: 50%; 
padding: 0px; 





(3) 把 文档 以 register.css 为 文件 名 保存 在 register/css 文件 夹 下 


@ 0145] 
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V pup 


5.8.2 ”网 页 的 头 部 、 尾 部 和 数据 库 连 接 文件 
代码 文件 : reghead.php、regbottom.html 和 sys conf.inc 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlnss"http://www.w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8"» 
X«title»«?php echo $title; ?></title> 
<link href-"css/register.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="app"> 
<div id="top"> 
<img src-"images/logo.gif" width-"180" height-"50" /><img 
src-"images/login.jpg" width-"600" height="50" /»«/div» 





(3) 把 文档 以 reghead.php 为 文件 名 保存 在 register 文件 夹 下 。 


\ - 





这 只 是 网 页 的 一 部 分 ， 由 于 每 个 网 页 中 的 头 部 和 尾部 都 是 相同 的 ， 从 代码 重用 的 角度 ， 把 它们 存放 在 
一 个 独立 的 文件 中 ， 用 系统 函数 require_once() 包 含 并 运行 在 网 页 中 ， 能 提高 代码 效用 。 

第 6 行 : 根据 不 同 的 页 面 设置 不 同 的 标题 ，$title 在 包含 该 页 之 前 赋值 。 

第 7 行 : 链接 样式 文件 css/register.css。 

第 10 行 : 定义 了 一 个 区 域 ， 采 用 类 样式 app。 注 意 此 行 <div> 的 闭 标记 未 包含 在 此 文件 中 。 

第 11 一 12 行 : 定义 了 一 个 区 域 ， 采 用 类 样式 top， 规 划 logo 和 banner。 

(4) 在 Dreamweaver 中 ， 打 开 站 点 根 文件 夹 中 的 bottom.html。 

(5) 把 文件 以 regbottom.html 为 文件 名 另 保存 在 register 文件 夹 下 ， 并 修改 链接 的 样式 
文件 为 css/register.css。 

(6) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

(7) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 

















<!--sys_conf.inc: 系 统 配置 文件 --> 


1 

? MS 

3 // 数 据 库 配 置 全 局 变量 

4 $DBHOST-"localhost"; 
Q 


p 
D 
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SDBUSER-"root"; 
S$DBPWD-""; 





(8) 把 文档 以 sys_conf.inc 为 文件 名 保存 在 register 文件 夹 下 。 
M 
m eagi 


把 数据 库 的 配置 参数 作为 全 局 变量 存放 在 一 个 单独 的 文件 中 有 利于 维护 .使 用 系 
含 到 PHP F, RXRASEEPT. 





x4 include once( ) 


5.8.8 ”注册 的 主页 和 处 理 程序 
代码 文件 : regindex.php, login.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ,输入 如 下 代码 


<?php 
$msg=" 带 * 的 是 必须 填写 的 ! «br /»"; // 初 始 化 自 定义 变量 
if(isset($ GET['msg'])) $msg-$ GET['msg'];// 如 果 是 第 二 次 进入 会 通过 GET 方式 
传递 msg 的 值 
Spp-0; //0- 首 次 进入 ; 1- 提 交 后 登录 成 功 ，2- 提 交 后 没有 检测 到 是 会 员 ， 需 要 注册 
if(isset($ GET['pp'])) $pp=$_GET['pp']; // 如 果 是 第 二 次 进入 ， 会 通过 GET 
方式 传递 pp 的 值 








$title=" 注 册 "; 
require once ("reghead.php"); // 网 页 的 title 属性 通过 变量 $title 设 定 
?> 
«div id="bt"> 请 登录 一 一 输入 用 户 名 和 密码 <hr/></div> 
<div id="bd" align="center"> 
<?php 
if ($pp==0) { 
za 
<script language="JavaScript"> 
function jcud(){ 
var cdsl-document.frm.userid.value; 
var cds2-document.frm.password.value; 
if (cdsl= Ji 
window.alert ("会 员 号 不 能 为 空 "); 


document.frm.userid.focus(); 





) 
else if (cds2 
window.alert( 






不 能 为 空 ") ; 


document.frm.password.focus(); 





qf 
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</script> 
«form method="POST" name-"frm" action="login.php"> 
«table width-"100$" border-"0"» 
<tr><td align="right"> 请 输入 会 员 号 </td> 
<td><input type-"text" name-"userid" size-"30" /»*«/td»«/tr» 
<tr><td align="right">gnbsp; 请 输入 窗 &nbsp; &nbsp;fij«/td» 
<td><input type="password" name="password" size-"21" />*</td> </tr> 
<tr><td colspan="2" align="center"> 
«input type="submit" name="subm" value=" 登 录 " onmousedown-" jcud() ;" /></td> 
</table></form> 





<?php 
) 
else if ($pp==2) { 





?> 
<form method="POST" action="applycard.php"> 
<input type="submit" name-"subm" value=" 注 册 成 为 会 员 /></form> 

<?php 
?> 

«/div» 

«div id-"err" align-"center"»«?php echo $msg; ?»«br/»«br/»«/div» 

<hr/> 


<iframe scrolling-"no" width-"780" height-"70" src-"regbottom.html" 
marginwidth-"0" marginheight-"0" border-"0" frameborder-"0" align-"center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 





(3) 把 文档 以 regindex.php 为 文件 名 保存 在 register 文件 夹 下。 





Prags 


regindex.php 使 用 表单 输入 用 户 信息 ， 使 用 JavaScript 对 输入 作 有 效 性 检查 ， 并 在 login.php 处 理 表 
单数 据 。 
第 2~5 行 : 设置 在 下 方 反馈 提示 栏 上 的 显示 信息 Smsg 和 对 输入 的 判断 信息 Spp。 若 是 第 二 次 进入 该 
页 ， 则 使 用 GET 方式 传递 来 的 数据 作为 显示 信息 。 

第 6 行 : 设置 浏览 器 上 该 页 面 的 标题 。 

第 7 行 : 使 用 系统 函数 require_once() 包 合 reghead.php. 

第 9 行 : 设置 标题 区 域 ， 应 用 了 bt 样式 。 

第 10 一 46 行 : 设置 表单 区 域 ， 应 用 了 bd 样式 。 其 中 

第 14-38 行 : 定义 用 户 “登录 ”输入 的 表单 ， 提 交 方 式 为 POST， 处 理 程序 为 login.php. 
第 14 一 27 行 : 使 用 JavaScript 代码 对 用 户 表单 输入 合法 性 检查 ， 这 里 主要 是 检查 输入 不 能 为 空 ; 
第 35 行 : 当 单 击 时 ， 首 先 触 发 JavaScript 函数 jcud0， 检 查 输入 的 合法 性 ， 单 击 它 再 执行 处 理 
程序 login.php。 
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第 39~45 行 : 定义 用 户 “注册 成 为 会 员 ” 的 表单 ， 处 理 程序 applycard.php. 
第 47 行 : 设置 反馈 区 域 , 应 用 了 err 样式 , Smsg 是 在 login.php 中 设置 的 字符 串 变量 , 记录 反馈 信息 ， 
由 GET 方式 传递 到 该 页 面 . 
第 49 4: 使 用 iframe 标记 加 载 regbottom.html。 
第 504r: 关闭 在 reghead.php 定义 的 div 标记 





(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代 币 


«?php 
Gsession start(); // 启 动 session 变量 ， 注 意 一 定 要 放 在 首 行 
$userid=$ POST["userid"]; $password-$ POST["password"]; // 获 取 表 单 变量 的 值 
$ SESSION["userid"]-$userid; // 把 用 户 输入 的 userid 设置 为 全 局 变量 $_SESSION 

["userid"] 

include("sys conf.inc"); // 建 立 与 SQL 数据 库 的 连接 
$connection=@mysql_connect ($DBHOST, $DBUSER, SDBPWD) or die ("无 法 连接 数据 库 ! ") ; 
Gmysql query("set names 'utf8'") ; // 设 置 字符 集 ， 防 止 中 文 显示 乱码 
Gmysql select db(SDBNAME) or die ("无 法 选择 数据 库 ! "); 
$query-"SELECT * FROM userinfo WHERE userid-'".$userid."'"; // 查 询 用 户 信 息 
$result=@mysql]_query ($query, $connection) or die ("数据 请 求 失败 1! "); 














if($row=mysql fetch array ($result) ) { 
if($row['password']--$password and $password!= "")( // 身 份 认证 成 功 
$query-"SELECT * FROM usercard WHERE userid-'".$userid."'"; // 查 询 用 户 卡 信息 
$resultl-8mysql query ($query, $connection) or die (" 数 据 请 求 失败 2! "); 
if($rowc-mysql fetch array($resultl))|(  // 查 询 购书 卡 信息 
$query="SELECT * FROM card WHERE cardno='".$rowc['cardno']."'"; 
$result2=@mysql_query ($query, $connection) or die (" 数 据 请 求 失败 3! "); 
EAM; 








mysql close($connection) or die ("关闭 数 据 
$rowcc-mysql fetch array ($result2); 
if ($rowcc['balance']<10) { // 判 断 购书 卡 余额 
$msg- $userid.": 你 好 ! 该 卡 中 余额 不 足 10 元 ， 请 向 卡 内 注资 或 到 会 员 管理 中 申请 
新 购书 卡 ! n; 


echo "<meta http-equiv-'Refresh' content-'0; url- regindex.php? 





msg-$msg&&pp-1l'»"; 
) 
else( 
$msg- $userid.": 你 好 ! 注册 成 功 ! 可 以 使 用 购书 卡 购 书 啦 ! "; 
echo "<meta http-equiv-'Refresh' content-'0;url- regindex.php? 
msg-$msg&&pp-1l'»"; 
) 
H 
else( 
$msg=$userid." 你 好 ! 注册 成 功 ! 可 以 购书 啦 ! 但 没有 购书 卡 ， 可 到 会 员 管理 中 申请 购 
HE 
echo "<meta http-equiv-'Refresh' content-'0;url- regindex.php?msg- 
$msg&&pp-1l'2"; 
} 
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} 
elsel{ 
$msg=" 密 码 不 正确 ， 请 重新 输入 !"; 
echo "<meta http-equiv='Refresh' content='0; url=regindex.php?msg= 
$msg'>"; 
} 
} 
else{ 
$msg=" 不 存在 该 会 员 id， 请 注册 为 新 会 员 !"; 
echo "<meta http-equiv-'Refresh' content='0;url=regindex.php?msg= 
$msg&&pp-2'»"; 
} 








2» 

(6) 把 文档 以 login.php 为 文件 名 保存 在 register XHK Fo 
Mirasa 

(1) 程序 中 用 到 的 变量 详解 如 表 5.6 所 示 。 


R56 程序 中 用 到 的 变量 

























变 量 名 取 o ^d $ X 
S POST["userid"] 表单 中 输入 的 内 容 hit. 记录 指定 表单 元 素 的 什 
$ SESSION['userid'] rm 记录 SESSION 变量 userid 的 值 
Smsg ; 自 定义 变量 
Suserid i 自 定义 变量 
Spassword 自 定义 变量 
Srow,$rowc,Srowec Aen. 
Sconnection 记录 连接 数据 库 的 句柄 
Squery SQL 命令 t. id SQL 命令 
Sresul,$resultl,$result2 | 查询 数据 集 自 定义 变量 。 记 录 执 行 SQL 命令 后 的 返回 结果 


(2) 程序 中 用 到 的 函数 详解 如 表 5.7 所 示 . 


R57 程序 中 用 到 的 函数 













session start() 


数 














include once("filename") 





数 取 字 型 
: 服务 器 名 ,用 户 名 ,用 户 密码 


| 

| 系统 函数 。 文件 
mysql query) | 参数 为 SQL 命令 

| 

| 


系统 函数 。 连 接 指定 的 MySQL 数据 库 





mysql_connect() 














。 执 行 SQL 命令 
mysql_select_db() 参数 为 数据 库 名 。 选 择 数据 库 文件 












系统 函数 。 关 闭 数据 库 文 
系统 函数 。 以 数组 显示 返 


mysql close() 





参数 为 标识 连接 数据 库 的 句柄 
参数 为 查询 数据 集 











mysql fetch array() 





当前 记录 








(3) 程序 中 用 到 的 SQL 命令 详解 如 表 5.8 所 示 . 


第 S 章 会 员 注册 和 管理 设计 与 数据 获取 


表 5.8 程序 中 用 到 的 SQL 命令 











& x 
设置 数据 库 的 字符 集 为 utf-8 
查询 表 userinfo 中 指定 userid 的 所 有 记录 
查询 表 usercard 中 指定 userid 的 所 有 记录 
查询 表 card 中 指定 cardno 的 所 有 记录 


命令 格式 





set names 'utf-8' 

SELECT * FROM userinfo WHERE userid-'Suserid" 
SELECT * FROM usercard WHERE userid-"Suserid' 
SELECT * FROM card WHERE cardno-"$rowc[cardno]' 








(4) 对 程序 中 各 行 代码 的 解读 . 
第 2 行 : 启动 session。 前 面 的 @ 用 于 屏蔽 错误 报告 。 当 已 经 启动 或 在 配置 文件 php.ini 设置 了 自动 启动 
的 情况 下 ， 若 在 php.ini 中 没有 设置 关闭 错误 报告 ， 就 会 出 现 错误 报告 。 
第 3 行 : 使 用 系统 预定 义 变量 $_ POST 获取 用 户 填写 的 表单 数据 。 
第 4 行 : 把 用 户 输入 的 userid 设置 为 全 局 变量 $_SESSION["userid"]， 可 以 在 其 他 页 面 使 用 。 
第 6 一 8 行 : 连接 数据 库 。 此 处 使 用 的 是 原生 MySQL API， 相 关内 容 见 第 6 章 。 
第 9~10 行 : 查询 表 userinfo 中 指定 userid 的 用 户 信息 ， 获 得 查询 数据 集 ; 
第 11 一 42 行 : 验证 用 户 身份 。 
第 11 行 :PHP 的 MySQL 函数 mysql_fetch_array() 获 得 查询 数据 集中 的 记录 并 赋予 数组 变量 $row。 
第 12 一 34 行 : 用 户 输入 密码 正确 (是 会 员 )。 
第 13 一 14 行 : 设置 SQL 语句 ， 查 询 表 Usercard 中 指定 userid 的 用 户 购 书 卡 信息 。 
第 15 一 28 行 : 用 户 拥有 购书 卡 。 
第 16 一 17 £r: 设置 SQL 语 负 ,查询 表 card 中 指定 cardno 的 购书 卡 信息 。 
第 1847: 使 用 mysql_close(Sconnection) 关 闭 数 据 库 连 接 。 
第 19 行 : 使 用 mysql fetch array() 获 得 查询 数据 集中 的 记录 并 赋予 数组 变量 Srowcc。 
第 20 一 23 41: 卡 内 余额 少 于 10 元， 
第 21 行 : 用 户 设置 反馈 信息 Smsg.。 
第 22 行 : 刷新 regindex.php， 同 时 传递 反馈 信息 msg # pp. 
第 24 一 27 行 : 卡 内 余额 大 于 10 元 ; 
4 25—26 4: 设置 反馈 信息 Smsg; 刷新 regindex.php, 同时 传递 反馈 信息 msg 和 pp. 
第 29 一 32 行 : 用 户 没有 购书 卡 。 
第 30、31 行 : 设置 反馈 信息 Smsg; 刷新 regindex.php， 同 时 传递 反馈 信息 Smsg. 
第 34 一 37 行 : 用 户 输入 密码 错误 . 
5 35. 36 4r: 设置 反馈 信息 Smsg; 刷新 regindex.php， 同 时 传递 反馈 信息 Smsg。 
第 39 一 42 行 : 不 是 会 员 。 
第 40 和 41 行 设置 反馈 信息 $msg; 刷新 regindex.php， 同 时 传递 反馈 信息 Smsg 和 pp. 





5.3.4 ”用 户 申请 购书 卡 页 和 处 理 程序 


代码 文件 : applycard.php、apply.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 





<?php 
Gsession start();  // 启 动 session 变量 ， 注 意 一 定 要 放 在 首 行 


Suserid-$ SESSION["userid"]; 
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if(isset($ GET['msg'])) $msg-$ GET['msg']; 

$title=" 注 册 购书 卡 "; 

require once("reghead.php"); 

es 
<script language="JavaScript"> 
function jcidd(){ 
var idss=window.frm.userid.value; 
var cds-window.frm.cardno.value; 
var pds=window.frm.cardpsd.value; 
if (idss==""){ 
window.alert(" 新 会 员 号 不 能 为 空 ") ; 





window.frm.userid.focus(); 

) 

else if(idss.length«4 || pds.length»30)[ 
window.alert ("新 会 员 号 长 度 不 合法 , 请 重新 输入 ") ; 
window.frm.userid.value=""; 
window.frm.userid.focus(); 

) 

else if (cds a 
window.alert ("购书 卡号 不 能 为 空 ") ; 





window.frm.cardno.focus(); 
) 
else if (pds--"")( 
window.alert ("购书 卡 





码 不 能 为 空 ") ; 


window.frm.cardpsd.focus(); 


) 








</script> 
<div id="err"> 注 册 购 书 卡 &gt; &gt;</div> 
«div id="bt"> 填 写 购书 卡 信息 <hr /></div> 


<div id="bd"><form method="POST" name="frm" action="apply.php"> 
«table width-"100$" border="0" cellspacing="0" class-"tdl"» 
<tr><td align="right"> 新 会 员 号 </td> 
«td» «input type-"TEXT" name-"userid" value-"«?php echo $userid; ?»" 
Size-"30"/» 
(位 数 4 一 30， 必 须 由 字母 与 数字 组 成 )</td></tr> 
<tr><td align="right"> 购 书 卡号 </td> 
«td» «input type-"TEXT" name-"cardno" size-"30"/» 
将 在 购物 卡 中 计算 ) </td></tr> 
<tr><td align="right"> 购 书 卡 密码 </td> 





<td><input type="password" name-"cardpsd" size-"30"/»«/td» </tr> 
<tr><td colspan="2" align="center"> 
<input type="submit" name-"select" value=" 下 一 步 " onmousedown= 
"jcidd()"» 
«input type="submit" name-"select" value=" 跳 过 " ></td> </tr> 
«/table» 
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</form> 
</div> 
«div id-"ts"» 


1 .如 果 申 请 购书 卡 ， 就 填写 表单 信 单 击 “ 下 一 步 ” 按 钮 。<br /> 
2 .如 果 不 想 申请 购书 卡 ， 就 单 击 “ 跳 过 ”按钮 。 
</div> 
<div id="err" align="center"><?php echo $msg; ?> </div> 
<hr/> 
<iframe scrolling="no" width-"780" height="70" sr: 





regbottom.html" 
0" align="center" > 








marginwidth-"0" marginheight-"0" border-"0" frameborder- 
不 支持 </iframe> 
«/div» 
</body> 
</html> 


(3) 把 文档 以 applycard.php 为 文件 名 保存 在 register 文件 赤 下 








T: 使 用 JavaScript 代码 对 用 户 表单 给 关 合 法 性 进行 检查 ， 这 里 主要 是 检查 输入 不 能 为 空 ， 
3 立 用 了 er A. HT EE ARAS 
第 34 行 : 设置 div RIR, AMT bt 样式 个 用 于 设置 浏览 器 内 的 页 面 标题 
第 35 一 50 行 : 设置 表单 区 域 ， 应 用 了 -bd 样式 ， 表 单 的 提交 方式 为 POST， 处 理 程序 为 applyphp。 其 中 
第 46 一 47 行 : 定义 两 个 按钮 , 当 单 击 “ 下 一 步 ”按钮 时 ， 首 移 触 发 JavaScript 函数 jcud( )， 检 查 
输入 的 合法 性 ， 通 过 后 再 执行 处 理 程序 apply.php; 当 单 击 “ 跳 过 ”按钮 时 ， 直 接 
执行 处 理 程序 apply.php. 
第 51—54 4r: 设置 提示 区 域 ， 应 用 了 ts 样式 
第 55 行 : 设置 反馈 区 域 ， 应 用 了 err 样式， 显示 由 $_GET[ msg'] 记录 的 反馈 信息 ， 它 由 GET 方式 传 
递 到 该 页 面 。 
(4) 新 建 PHP 文档 。 
(5) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
$userid=$ POST["userid"]; $select-$ POST["select"]; 
Scardpsd-$ POST["cardpsd"]; $cardno-$ POST ["cardno"]; 
if($select--"gi") 
$ SESSION["userid"]-$userid; 
$ SESSION["cardno"]-""; 
$ SESSION["balance"]-0.0; 
echo "<meta http-equiv-'Refresh' content-'0; url= applysrc.php?msg-'»"; 











) 

if ($select==" 下 一 步 ") { 
require once("sys conf.inc"); // 建 立 与 SOL 数据 库 的 连接 
G$connection-mysql connect ($DBHOST, $DBUSER, $DBPWD) or die ("无 法 连接 数据 库 ! 
mysql_query ("set names-'utf8'") 
mysql_select_db($DBNAME) or die ("无 法 选择 数据 库 ! 
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$query-"SELECT * FROM usercard WHERE useri 
$result=mysql_query ($query, $connection) or die("j 





'".$userid." 
览 失败 ! 1") ; /7 向 数据 库 发 
送 查 询 请 求 





if ($row 
Smsg= 





ysql fetch array($result) ){ 
该 会 员 号 已 经 被 人 使 用 , 请 重新 填写 "; 
echo "<meta http-equiv-'Refresh' content-'0;url-applycard.php? 





msg-$msg'»"; 


) 


else( 
$ SESSION["userid"]-$userid; 
$query-"SELECT * FROM "card? WHERE cardno-'".$cardno."'"; 


$result=@mysql_query ($query, $connection) or die(" 浏 览 失 败 ! 2"); 
if ($row=mysql fetch array($result)){ 

if ($row['cardstatus']=="N"){ 
A FA fe HH ! 


echo "«meta http-equiv-'Refresh' content-'0;url- applycard.php? 





msg-$msg'»"; 
) 
else if($row['cardpsd']--$cardpsd) { 
$ SESSION["cardno"]-$cardno; 
$ SESSION["balance"]-$row['balance']; 
$msg- 








echo "<meta http-equiv-'Refresh' content-'0;url- applysrc.php? 
msg-$msg'»"; 





3 错误 ， 请 重新 输入 ! t; 
echo "«meta http-equiv-'Refresh' content-'0;url- applycard.php? 
msg-$msg'»"; 


) 
else( 
$msg=" 不 存在 该 卡号 ,请 重新 输入 "; 
echo "<meta http-equiv='Refresh' content='0;url=applycard.php? 
msg-$msg'»"; 


) 





(6) 把 文档 以 apply.php 为 文件 名 保存 在 register 文件 夹 下 。 


Y 
Doesgi 


第 2 一 3 行 : 获取 提交 表单 中 的 数据 。 
第 4-9 行 : 当 单 击 “ 跳 过 ”按钮 时 ，2 个 全 局 变量 置 “ 零 ”及 记录 用 户 输入 的 会 员 号 ; 刷新 页 面 
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applysre.php， 即 在 当前 页 面 中 显示 applysrc.php. 
第 10 一 46 行 : 对 当 用 户 单 击 了 “下 一 步 ”按钮 后 的 处 理 。 其 中 
第 15 一 16 47: 设置 SQL 语句 ， 查 询 表 usercard 中 指定 userid 的 记录 。 
第 17 一 20 行 : 该 用 户 的 会 员 号 在 数据 库 中 已 存在 。 设 置 反 馈 信息 $msg; 刷新 applycard.php， 同 时 传 
递 信息 $msg-。 
第 21 一 45 行 : 该 用 户 的 会 员 号 没有 申请 过 购书 卡 。 
22 行 : 需要 设置 全 局 变量 $_SESSION 记录 userid， 在 网 页 中 传递 此 数据 。 
第 23~24 行 : 设置 SQL 语句 ， 查 询 表 card 中 指定 cardno 的 记录 。 
第 25 一 40 行 : 当 购书 卡号 存在 时 。 
第 26 一 29 行 : 当 购 书 卡 的 状态 为 N( 不 可 用 ) 时 ， 设 置 反 馈 信 息 Smsg; 刷新 applycard.php， 同 时 
传递 信息 Smsg. 
第 30~35 行 : 当 购 书 卡 可 用 并 且 密码 输入 正确 时 。 
第 31~32 行 : 需要 设置 全 局 变量 $_ SESSION 记录 cardno 和 balariee， 在 网 页 中 传递 此 数据 。 
第 33 一 34 行 : 设置 反馈 信息 Smsg; 进入 applysrc.php， 输 入 用 户 的 详细 资料 。 
第 36~39 行 : 当 购书 卡 可 用 但 密码 输入 错误 时 ， 设 置 反馈 信息 Smsg; 刷新 applycard.php， 同 时 
传递 信息 $msg。 
第 41—44 行 : 当 购 书 卡号 不 存在 时 , 设置 反馈 


5.3.5 ”注册 用 户 资料 页 与 处 理 程序 





X 








Smsg; |t applycard.php, 同时 传递 信息 $msg。 


代码 文件 : applysrc.php、success.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
Q) 单 击 “ 代 码 ”标签 切换 到 “代码 ”视图 ,输入 如 下 代码 。 
<?php 
$title=" 新 会 员 申请 "; $msg=""; 
if (isset ($_GET['msg'])) $msg-$ GET['msg']; 
require_once ("reghead.php"); 
?» 
«script language-"JavaScript"» 
function pdsr()( 
var pds-window.frm.password.value; 
var pdsl-window.frm.passwdl.value; 
var id-window.frm.userid.value; 
window.frm.phone.value; 
Mat 
window.alert (" 会 员 号 不 能 为 室 ! ") 7 
window.frm.userid.focus(); 
) 
elscer£(pdssenhyt 
window.alert(" 密 码 不 能 为 空 ! ") 
window.frm.password.focus(); 
} 
else if(pds.length«6 || pds.length>20){ 
window.alert(" 密 码 长 度 不 合法 ,请 重新 输入 ! 7 


window.frm.password.value-" 
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window.frm.password.focus(); 
) 
else if(pdsl!-pds) { 
window.alert (" 两 次 密码 输入 不 匹配 ,请 重新 输入 ! 7 


window.frm.passwdl.value 





window.frm.passwdl.focus(); 


) 
else if(phn--"") ( 
window.alert ("电话 号 码 不 能 为 





window.frm.phone.focus(); 


) 
</script> 
«div id="err"><a href="applycard.php?msg="> 注 册 购 书 卡 </a>&nbsp; | snbsp; 填 写 
会 员 信息 &gt;&gt; </div> 
«div id="bt"> 填 写 会 员 信息 <hr /></div> 
<div id="bd"><form method="POST" name="frm" action="success.php"> 
«table width="100%" border="0" cellspacing="0" class-"tdl"» 
<tr><td colspan-"2" align="center" > 带 &nbsp;*&nbsp; 的 选项 是 必须 填写 的 
«/td»«/tr» 
<tr><td width="30%"align="right"> 新 会 员 号 </td> 
<td id="bitem"><input type="TEXT" name="userid" value="<?php 
echo $ SESSION ['userid'];?»" siz 20" /»&nbsp;*&nbsp; &nbsp; </td></tr> 
«t-- bili A SEE 5-77 
<tr><td align="right" class="tdl"> 新 会 员 密码 








<td><input type-"password" name-"password" size="20" 
/>&nbsp; *&nbsp;&nbsp; (密码 位 数 6 一 20， 必 须 由 字母 与 数字 组 成 ) </td></tr> 
<tr><td align="right"> 青 次 输入 密码 </td> <!-- 输 入 两 次 密码 以 确 i 











无 误 --> 
<td><input type-"password" size-"20" name-"passwdl" 
/»&nbsp;*&nbsp; &nbsp; </td></tr> 
<tr><td align="right"> 姓 名 </td> 
<td><input type="TEXT" size="20" name="username" /></td></tr> 
<tr><td align="right">Email</td> 
<td><input type-"TEXT" size="20" name-"email" /></td></tr> 
<tr><td align="right"> 邮 编 </td> 
<td><input type-"TEXT"size-"20" name-"post" /></td></tr> 
«tr»«td align=right> 地 址 </td> 
<td><input type="TEXT" name="addr" size="40" /></td></tr> 
<tr><td align="right"> 电 话 号 码 </td> 


5 
5 


1 
5 
3 


ww 





E 





wm wm UA tA 


<td><input type-"TEXT" name-"phone" size-"20" /»&nbsp;*&nbsp; 
&nbsp;«/td»«/tr» 
<tr><td colspan-"2" align-"center"»«input type="submit" value=" 
提交 " onmousedown- "pdsr()";/» </td></tr> 
</table> 
</form> 
</div> 
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<div id-"err" align-"center"»«?php echo $msg; ?»«/div» 

<hr/> 

<iframe scrolling-"no" width-"780" height-"70" src-"regbottom.html" 
marginwidth-"0" 
marginheigh 





0" border-"0" frameborder-"0" align-"center" > 不 支持 </iframe> 
«/div» 
</body> 
</html> 


(3) 把 文档 以 applysrc.php 为 文件 名 保存 在 register 文件 夹 中 。 





Miragi 
本 页 代码 通过 表单 收集 用 户 的 相关 资料 。 表 单 处 理 程序 是 success.php。 


(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 
$title=" 注 册 完 成 "; $msg- 
require once ("reghead.php"); 
if($ SESSION['userid']!-$ POST['userid']) ($cardno- 
else (S$cardno-$ SESSION["cardno"];) 
$ SESSION['userid']-$ POST['userid']; 
$userid=$ POST["userid"];S$username-$ POST["username"]; 
$password-$ POST["password"]; $email-$ POST["email"]; 
$addr-$ POST["addr"]; $post-$ POST["post"]; $phone-$ POST["phone"]; 
include ("sys conf.inc"); 
G$connection-mysql connect ($DBHOST, $DBUSER, $DBPWD) or die ("无 法 连接 数据 库 1") ; 
mysql query("set names 'utf8'") 
mysql select db(SDBNAME) or die(" 无 法 选择 数据 库 ! "); 
$query="SELECT * FROM userinfo WHERE userid-'".$userid."'"; 
$result-mysql query($query,$connection) or die ("浏览 失败 ! 1"); 











if($row-mysql fetch array($result))( 
$msg=" 该 会 员 号 已 经 被 人 使 用 , 请 重新 填写 "; 
echo "<meta http-equiv-'Refresh' content='0;url= applysrc.php?msg 





-$msg'»"; 
) 
else{// 建 立会 员 号 和 购物 卡号 的 联系 
if ($cardno!=""){ 
$query="SELECT * FROM card WHERE cardno='".$cardno. 
$result-8mysql query ($query, $connection) or die (" 存 入 数据 库 失败 ! 0"); 
$cardpsd=mysql_fetch_array ($result) ['cardpsd']; 
$query-"INSERT INTO usercard (userid,cardno,password) VALUES 
('".$userid 
$result: 









-Scardnos rm cardped yrs 
mysql query ($query, $connection) or die (" 存 入 数据 库 失 败 ! 1"); 
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// 修 改 卡号 状态 
$query-"UPDATE card SET cardstatus -'N' WHERE cardno-'".$cardno."'"; 
$result-8mysqgl query(S$query,$connection) or die(" 存 入 数据 库 失 败 ! 2") ; 
) 
// 建 立新 会 员 身 份 
date default timezone set('PRC'); // 设 置 中 国 时 区 ; 
$time=Date ("Y-n-j G:i"); 
$query="INSERT INTO userinfo (userid, username, password, email, addr, post, 
phone, createtime) VALUES ('".$userid."', '".$username."', '".$password."', 
IN Semsid ee m Snost-em ue Sphopne mu snos Eme tms: 
$result-mysgl query($query,$connection) or die(" 存 入 数据 库 失败 ! 3") 7 
mysql_close ($connection) or die(" 关 闭 数据 库 失败 ! "); 
// 反 馈 申 请 成 功 信息 
S$msg=" 您 的 会 员 号 为 :" .$userid."<br/>"; 
if ($cardno!-"")( 
"购书 卡号 : ".Scardno."«br/»"; 
: ".$_SESSION["balance"]; 








«div id="err"> 注 册 购 书 卡 | 填 写 会 5 完成 </div> 
«div id="bt"> 共 喜 您 已 经 完成 所 有 申请 手续 <hr /></div> 
«div id-"bd" class-"tdl" align="center"><?php echo $msg; ?></div> 
<hr/> 
<iframe scrolling="no" width="780" height="70" src="regbottom.html" 
marginwidth="0" marginheight="0" border="0" frameborder="0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 





(6) 把 文档 以 success.php 为 文件 名 保存 在 register 文件 夹 中 。 


(^ 代码 解读 


第 4 一 6 行 : 重新 确定 全 局 变量 的 取 值 。 若 在 资料 页 中 输入 的 userid 与 在 申请 卡 页 面 输入 的 相同 ， 才 
能 获取 全 局 变量 $ SESSION["cardno"]， 否 则 把 它 置 零 ; 同时 更 新 8$_ SESSION['userid']. 

第 7 一 9 行 : 获取 提交 表单 中 的 数据 。 
第 16 一 19 行 : userid 不 可 用 的 处 理 . 设置 反馈 信息 $msg; 刷新 applysrc.php, 同时 传递 反馈 信息 $msg。 
第 21 一 30: 对 有 效用 户 申请 的 购书 卡 处 理 。 其 中 

第 22 一 23 行 : 设置 SQL 语句 ， 向 表 card 查询 指定 卡号 的 记录 ， 记 录 在 数据 集中 。 

第 24 行 : 从 查询 字符 集中 通过 数组 方式 获取 卡 的 密码 

第 25 一 26 行 : 设置 SQL 语句 ， 向 表 usercard 添加 记录 

第 28 一 29 41: 修改 这 个 卡号 的 状态 为 不 可 用 (N)。 
第 32 一 36 行 : 建立 新 会 员 身份 资料 。 其 中 

第 32 一 33 行 : 设置 时 区 和 时 间 格 并 
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o mud ^ 


5$ 34—35 行 : iX E SQL 语句 ， 向 表 userinfo 添加 记录 ， 记 录 各 字段 的 数据 。 
第 38 一 42 行 : 设置 反馈 信息 Smsg。 其 中 

第 38 行 : 反馈 信息 为 用 户 申 请 的 userid。 

第 39 一 42 行 : 当 用 户 申 请 了 购书 卡 时 ， 反 馈 信 息 为 卡号 和 金额 。 


gr E 


5.3.6 ”调试 代码 





(1) 确认 regindex.php 等 相关 文件 已 在 服务 器 访问 目录 (如 D:\wamp\ www\wuya) 的 子 目 
录 register 下 。 
D 启动 浏览 器 ， 在 地 址 栏 上 输入 http: /Mocalhost/wuya/registey/regindex php, f% Enter 


键 后 ， 效 果 如 图 5.5 所 示 。 x 


NS 


o x 
wr — D. o Bam KANN . 


IIT. — 
aul 


MO WAP 6f 





22705 H5 zarm 
SÉ un AD Ke 


O nik Ux" deter, 若 有 一 Hxc 会 弹出 如 图 5.6 所 示 的 警示 框 ， 这 是 在 浏 
LERAP ENGGEH. 


| Aves 小 seres 
| Em Ex 


图 5.6 输入 检查 警示 框 
© 若 输入 的 会 员 号 与 密码 都 正确 ， 则 出 现 图 5.7 所 示 的 信息 。 
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57 ”登录 成 功 页 面 
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9 
© 若 输 入 的 会 员 号 不 存在 ， 则 出 现 图 5.8 所 示 的 信息 。 


e 5) [E hep/Nocalhostwuya/register/regindexpho?r D - & | ism 


Drise $t oda h zuo 





请 登录 一 一 输入 用 户 名 和 密码 

















注册 成 为 会 员 
不 存在 该 会 员 号 ,请 注册 为 新 会 员 ! 








Copyright@2016 wuyabook@com 无 涯 网 上 书店 版 权 所 有 
专 中 华人 民 共和 国电 信 与 信息 服务 业务 经 营 许可 证 》 编 号 ; 沪 ICPiExxxxxx 号 
建议 浏览 器 分 辩 素 ; 1024x768 





图 5.8 注册 页 面 
Q) 单 击 “ 注 册 成 为 会 员 ” 链 接 ， 可 见 如 图 5.9 RS 
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Copyright@2016 wuyabook@com 无 涯 网 上 书店 版 权 所 有 
亿 中 华人 民 共 和 国电 信 与 信息 服务 业务 经 营 许 可 证 》 编 号 : 沪 ICPiExxxxxx 号 
建议 浏览 器 分 状 牢 : 1024x768 





图 5.9 申请 购书 卡 页 面 

S un 

当 单 击 “ 下 一 步 ”按钮 时 ， 若 有 一 个 文本 框 中 没有 输入 或 再 次 登录 时 密码 输 错 ， 也 会 弹出 类 似 图 5.6 
的 警示 框 。 这 是 在 浏览 器 端 对 用 户 输入 的 合法 性 检查 . 

(4) 在 图 5.9 的 表单 中 输入 相关 信息 后 ， 单 击 “ 下 一 步 ” 按 钮 ， 在 服务 器 端 对 用 户 输入 
进行 合法 性 检查 。 

O 如 果 输入 的 新 会 员 号 已 经 被 注册 过 ， 则 在 提示 区 域 显示 “该 会 员 号 已 经 被 人 使 用 , 请 重新 填写 ”. 

Q) 如 果 输入 的 购书 卡 的 状态 是 “N"， 则 显示 “该 卡 不 能 

© 如 果 输 入 的 购书 卡 的 密码 错误 ， 则 显示 “密码 错误 ， 请 重新 输入 !”。 

图 如 果 输入 的 购书 卡号 错误 ， 则 显示 “不 存在 该 卡号 ， 请 重新 输入 ”。 

© 如 果 输入 的 信息 可 接受 ， 或 者 单 击 “ 跳 过 ”按钮 ， 进 入 如 图 5.10 所 示 的 界面 。 
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图 5.10 ”输入 会 员 资料 VA 
p K N 
S um NS 


CNN 
O 在 单 击 “ 提 交 ” 按 钮 前 ， 需 要 在 有 * 的 文本 框 中 输入 信息 , -对 用 户 输入 的 合法 性 检查 。 
O 如 果 在 如 图 5.9 所 示 的 页 面 中 输入 了 可 接受 的 信息 ， ced 记过 本 框 中 会 出 现 上 次 输入 的 serid 信息 . 
G) 单 击 网 站 LOGO 图 标 下 方 的 状态 栏 上 








eim e 链接 ， 能 回 到 图 5.9 所 示 的 申请 购书 卡 页 面 。 


(5) 在 图 5.10 所 示 的 表单 中 输入 相关 信息 局; 单 击 “ 提 交 ” 按 钮 ， 可 见 图 5.11 所 示 的 
界面 。 E 
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5.11 注册 成 功 界面 一 一 申请 了 购书 卡 


Lun 
如 果 没 有 申请 购书 卡 ， 将 看 到 如 图 5.12 所 示 的 界面 . 
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5.12 ”注册 成 功 界面 一 一 未 申请 购书 卡 
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54 会 员 管理 模块 的 实现 


"d 
V 准备 工作 
(1) 在 站 点 根 目 录 建 立 文件 夹 member 作为 存放 与 注册 相关 的 文件 。 
(2) 在 member 文件 夹 中 建立 文件 夹 css 和 文件 夹 images。 
(3) 在 Ulead GIF Animator 中 制作 管理 的 banner， 以 文件 名 member.gif 保存 在 文件 夹 
images. 
(4) 把 图 像 文件 logo.gif 也 放 在 文件 夹 images 中 。 





5.4.1 页 面 样式 表 


V. Css 编码 


代码 文件 ，member.css 


(1) 启动 Dreamweaver， 打 开 register\css 中 的 register.css. 
(2) 在 “代码 ”视图 中 ， 添 加 如 下 所 示 的 样式 表 。 


.nemulink( 
font-size: 14px; 
color: #099; 
width: 780px; 
margin-top: 5px; 
margin-bottom: 5px; 
background-color: #FFEFCE; 





(3) 把 文件 以 member.css 为 文件 名 保存 在 membercss 文件 夹 下 。 


V PHP 编码 

5.4.2 ”网 页 的 头 部 、 尾 部 和 连接 数据 库 
代码 文件 : memhead.php. membottom.html 和 opendata.php.inc 
(1) 在 Dreamweaver 中 ， 打 开 register 中 的 reghead.php。 


(2) 在 “代码 ”视图 中 ， 修 改 link 标记 行 、 图 像 文件 名 并 添加 第 13 行 ， 代 码 如 下 所 示 。 


«link href-"ERERECHUEBEERE rel="stylesheet" type="text/css" /> 


«img src-"images/logo.gif" width-"180" height-"50" /><img src= 
"images/EERBERNERHH' width-"600" height-"50" /»«/div» 


div a 














(3) 把 文件 以 memhead.php 为 文件 名 另存 在 member 文件 夹 下 
(4) 在 Dreamweaver 中 ， 打 开 站 点 根 文件 夹 中 的 bottom.html。 
(5) 修改 Link 标记 行 ， bs 文件 以 membottom.html 为 文件 名 另存 在 member 文件 夹 下 
(6) 在 Dreamweaver 中 ， 新 建 PHP 文档 
(7) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 
<?php 

// 建 立 与 MySQL 数据 库 的 连接 

$connection-8mysql connect ("localhost","root","") or die (" 无 法 连接 数据 库 ! "); 





@mysql query("set names 'utf8'"); 

Gmysql select db("member") or die(" 无 法 选择 数 所 

Spagemax-2; // 测 试 设置 为 2， 可 修改 为 10 等 其 他 数字 
?> 








(8) 把 文档 以 opendata.php.inc 为 文件 名 保存 在 member 文件 夹 下 


M 


1 , 
中 代码 解读 
把 建 





与 MySQL 数据 库 连 接 的 代码 存放 在 一 个 单独 的 文件 中 有 利于 维护 。 使 用 系统 函数 


include_once) &,& 5] PHP P, 3k sT vA 4 


第 6 行 自 定 类 变量 Spagemax 用 于 存放 分 示 每 页 中 最 多 行 数 ， 在 这 时 





定义 能 使 其 作用 于 所 在 页 面 


543 会 员 管理 的 主页 


代码 文件 ，memindex.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 
$title=" 会 员 管理 "; 
require once("memhead.php"); 
?» 
<div id="bt"> 欢 迎 进入 无 涯 书屋 的 会 员 管 理 系 统 </div><hr/> 
<iframe scrolling="no" width="780" height="70" src-"membottom.html" 
marginwidth="0" marginheight="0" border="0" frameborder="0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 
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(3) 把 文档 以 memindex.php 为 文件 名 保存 在 member 文件 夹 下 。 
544 ”用户 分 级 登录 页 和 处 理 程序 
代码 文件 : login.php、check.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
Serrmsg-"";  // 初 始 化 自 定 义 变量 
if(isset($ GET['errmsg'])) $errmsg=$_GET['errmsg'];// 如 果 是 第 二 次 进入 时 
$logn=$ GET['logn']; 
if ($logn==1) $title=" 进 入 购书 卡 专区 一 一 请 先 输入 会 员 号 及 密码 "; 
elseif ($logn==2) $title=" 修 改 个 人 资料 一 一 请 先 输入 会 员 号 
elseif ($logn==3) $title=" 密 码 查询 一 一 请 先 输入 会 员 号 " 
elseif ($logn==4) $title=" 站 长 登录 一 一 
include once ("memhead.php"); 

ok 









«script language-"javaScript" type-"text/javascript"» 
function pdsr()( 
var id-window.frm.userid.value; 
var pds-window.frm.password.value; 
if (id ) { 
window.alert (" 会 员 号 不 能 为 空 ") ; 











window.frm.username.focus(); 
) 
else if(pds--"")( 
window.alert(" 








HUS EA i); 


window.frm.password.focus(); 


) 
</script> 
<div id="bd" align="center"> 
<div id="bt"><?php echo $title;?><hr/></div> 
<form name="frm" action="check.php?logn=<?php echo $logn; ?>" method= "post"> 
<table width="100%" border= cellspacing="0" class-"tdl"» 
<tr><td width="30%" align="right"> 输 入 会 员 号 </td><td> <input type= 
"text" name-"userid"size-"30" /»«/td»«/tr» 
<?php if($logn!=3){ ?> 
<tr><td align="right"> 输 入 会 员 密码 </td><td><input type="password" 





name-"password" size-"20"/»«/td»«/tr» 
«?php } ?> 
<tr><td align="center"colspan=2><input type="submit" name="send" 
value=" 登 录 "”onmousedown="pdsr () ">&nbsp; gnbsp;<input type-"reset" value=" 重 
新 输入 "> </td></tr> 
</table> 
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</form> 
«div id-"err" align-"center"»«?php echo Serrmsg; ?><br /»«/div» 
«/div» 
<hr/> 
«iframe scrolling-"no" width-"780" height-"70" src-"membottom.html" 


不 支持 </iframe> 
«/div» 
</body> 
</html> 





s 把 文档 以 login.php 为 文件 名 保存 在 member 文件 夹 下 。 
) 在 Dreamweaver 中 ， 新 建 PHP 文 
单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 





«?php 
Gsession start(); 
$logn-$ GET['logn'];$psd-$ POST['password'];S$Suserid-$ POST['userid']; 
$ SESSION['userid']- $userid;$ SESSION['password']- $psd; 
include once ("opendata.php.inc"); 
if($logn--1 || $1ogn--2 || $1ogn--3)( 
$sql-"SELECT * FROM userinfo WHERE userid-'".$userid."'"; 
$records-mysql query($sql); 
$rows-mysql fetch array ($records); 
if(S$userid!-$rows['userid'])( 
$errmsg=" 输 入 用 户 的 会 员 号 的 不 正确 或 者 尚未 登录 为 会 员 !! "; 
header (" Ee INE NC e logn-$1logn"); 
) 
elseif(Spsd«»$rows['password'] && $1ogn!-3)(í 
$errmsg=" 密 码 输入 不 正确 !! t7 
header ("Location:login.php?errmsg=$errmsg&logn=$1ogn"); 
} 
elsel{ 
$_SESSION["userid"]=$userid; 
if(Slogn--3) header("Location:forget.php"); 
elseif ($logn==2) header("Location:modify.php"); 


) 
elseif ($1ogn--4)( 
$IP m-$ SERVER['REMOTE ADDR']; 
$sql-"SELECT * FROM administer WHERE userid-'".$userid."'"; 
$records-mysql query ($sql); 
$rows=mysql_fetch_array ($records); 
if($psd--$rows['password'] or $IP m==$rows['IP']) 
header ("Location:manager.php"); 





else{ 


marginwidth="0" marginheight="0" border="0" frameborder="0" align="center" > 


elseif ($logn==1) header("Location:usercard.php?pageno-'1'"); 
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$errmsg=" 输 入 管理 员 账 号 或 密码 错误 !! t7 


header ("Location:login.php?errmsg-S$errmsg&logn-$1ogn"); 





(6) 把 文档 以 check.php 为 文件 名 保存 在 member 文件 夹 下 


\ ans 


两 段 程序 的 关系 : login.php 是 包含 表单 的 显示 页 面 ，check.php 是 对 表单 的 处 理 。 
(1) 程序 中 用 到 的 变量 详解 如 表 5.9 所 示 。 


R59 程序 中 用 到 的 变量 






变量 名 m x 
Slogn 量 。 分 级 管理 的 编号 ， 与 各 个 链接 相对 应 
$ GET["logn"] 记录 URL 中 由 logn 传递 的 数据 
Serrmsg 反馈 信息 








Spsd、Suserid 

$ POST["userid"] 
$. POST["password"] 
$ SESSION['userid'] 
SIP m 字符 上 

Ssql 
Srecords 
Srows HA 
S SERVER['REMOTE ADDR] Hi; 


2) 程序 中 用 到 的 函数 详解 如 表 5.10 所 示 。 


双 和 会 员 号 
o 取 表 单 通过 POST 方式 提交 的 用 户 

输入 的 会 员 

预定 义 全 局 : SESSION 变量 userid 的 值 

里 员 所 拥有 的 TP 地 址 

SQL 命令 

执行 SQL 命令 后 的 返回 

记录 查询 数据 集中 当 

是。 记录 REMOTE_ADDR 指定 的 人 地 址 





表 5.10 程序 中 用 到 的 函数 










a a 


session_start( ) | 














。 启 动 一 个 会 话 





include once("filename") | E 
header("Location:URL") | 参 串 型 
mysql query( ) | 参 DE SQL 命令 
mysql fetch array( ) 参数 为 查询 数据 集 








Ee 向 到 指定 的 URL 
。 执 行 SQL 命令 
数 。 以 数组 方式 返回 当前 记录 











3) 程序 中 用 到 的 SQL 命令 详解 如 表 5.11 所 示 。 
X511 程序 中 用 到 的 SQL 命令 

命令 格式 
SELECT * FROM userinfo WHERE userid='$userid' 


$ x 
查询 表 userinfo 中 指定 userid 的 所 有 记录 
查询 表 usercard 中 指定 userid 的 所 有 记录 








SELECT * FROM administer WHERE userid = 'Suserid' 





会 员 注册 和 管理 设计 与 数据 获取 


" 
un 
n 


(4) 对 程序 中 各 行 代码 的 解读 。 
第 2 行 : 启动 session， 注 意 一 定 要 放 在 首 行 。 
第 3 行 : 使 用 系统 预定 义 变量 $_GET 获取 URL 中 的 logn， 使 用 系统 预定 义 变 量 $_POST 获取 用 户 表 
单 输入 的 内 容 。 
第 4 行 : 把 用 户 ID 和 密码 设置 为 全 局 变量 ， 在 页 间 均 可 使 用 。 
第 5 行 : 包含 文件 opendata.php.inc， 连 接 数 据 库 .。 
第 6 一 36 行 : 根据 分 级 分 别处 理 页 面 的 显示 。 其 中 
第 6 一 24 行 : 是 一 般 会 员 . 
第 7 一 9 行 : 从 数据 表 userinfo 提取 用 户 信息 。 
第 10 一 13 行 : 用 户 输入 的 会 员 号 在 数据 库 中 不 存在 的 处 理 ,设置 反馈 信 
第 14 一 17 行 : 用 户 输入 的 会 员 号 正确 但 密码 不 正确 的 处 理 。 设置 反 名 
第 18—23 行 : 用 户 输入 的 会 员 号 正确 且 密 码 正 确 的 分 级 处 理 。 
第 19 行 : 设置 SESSION 的 userid 48. 
第 20 行 : logn=3， 定 向 到 找 回 遗 忘 密码 页 面 。 
第 21 行 : logn=2， 定 向 到 修改 个 人 的 资料 页 面 。 
第 22 行 : logn=1， 定 向 到 申请 购书 卡 页 面 。 
第 25 一 36 行 : 管理 员 . 
第 26 行 : 获取 当前 用 户 的 IP 地址 。 
第 27 一 29 行 : 从 数据 表 administer PRAPA $. 
第 30 一 31 行 : 用 户 输入 的 密码 和 所 拥有 的 1P 地 址 都 对 时 重 定向 到 管理 员 页 面 。 
第 32 一 35 行 : 用 户 输入 的 密码 或 所 拥有 的 IP 地 址 不 对 时 的 处 理 . 设置 反馈 信息 ， 返 回 login.php. 


5.4.5 用 户 购书 卡 专区 页 和 处 理 程序 


代码 文件 : usercard.php、applycard.php、applycard_P.php 





返回 login.php. 
贵 信息 ， 返 回 login.php。 





(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 < 
(2) 单 击 关 代码 ”标签 ， 切 换 到 “代码 仿 视 图 ， 和 输入 如 下 代码 。 
«?php 
8$session start(); ”// 启 动 对 话 
| SESSION['userid'];  // 获 取 SESSION 的 userid 值 





$useri 








$errmsg: ; 
if(isset($ GET['errmsg'])) $errmsg-$ GET['errmsg']; 
S$pageno-(int)$ GET['pageno']; 
if(isset($ POST['pageno'])) 

if($ POST['pageno']!-"") $pageno-(int)$ POST['pageno']; // 获 取 pageno 的 值 
require once ("opendata.php.inc"); 
$sql-"SELECT* FROM usercard WHERE userid-'".$userid."'"; 
$records-mysql query ($sql); // 查 询 数据 表 usercard 中 指定 会 员 号 的 信息 
if(mysgl num rows($records)--0)| // 数 据 表 usercard 中 没有 指定 会 员 号 的 

$errmsg=" 没 有 申请 过 购书 卡 ! nz 


header ("Location:applycard.php?errmsg=$errmsg"); 





// 设 置 分 页 显示 开始 
$totalemysql num rows($records); // 统 计数 据 表 usercard 中 有 指定 会 员 号 的 信息 数 
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$1astp-ceil($total/$pagemax); // 计 算 最 大 页 码 

$infostr=" 目 前 共有 «font color=red>". $total."«/font» 张 购书 卡 ， 共 «font 
color-blue»" .$lastp."</font> 页 。"; // 设 置信 息 栏 上 的 信息 

if($pageno»$lastp) $pageno=$lastp;  ”// 当 前 页 码 超出 最 大 页 码 时 ， 设 置 为 最 大 页 码 

elseif($pageno«l) $pageno=1; // 当 前 页 码 小 于 1 时 ， 设 置 为 1 

$num£- ($pageno-1) *$pagemax+1; // 设 置 当 前 页 的 第 一 条 记录 数码 

$numl=$numf+$pagemax-1; // 设 置 当前 页 的 最 后 一 条 记录 数码 

if($numl»$total) $numl-$total; // 当 前 页 的 最 后 一 条 记录 超出 总 记录 时 , 设置 

为 超出 总 记录 数 
$infostr.-" 本 页 是 第 «font color=red>" .$pageno. "</font> 页 , "7 


S$infostr.=" 列 出 了 第 <font color=red>" .Snumf."</font> 到 «font color=red> 
".$numl."«/font» 条 记录 。"7 





if(S$pageno!-1) $msg-"«a href=".$ SERVER['PHP_SELF']."?pageno=1> 第 1 页 </a> "; 





else $ms //35 是 第 1 页 时 ， 不 要 设置 超 链 接 
$msg.-" // 加 分 隔 符 ! 
if ($pageno>1) // 当 前 页 大 于 第 1 页 时 ， 对 “上 一 页 


”要 设置 超 链接 
$msg.-"«a href=".$ SERVER['PHP SELF']."?pageno-". ($pageno-1) ."> 上 一 页 
«asm. 
if ($pageno«$1astp) // 当 前 页 小 于 最 后 页 
$msg.-"«a href-".$ SERVER['PHP SELF']. 
«/a» |"; 
if (Spageno!-$1astp) 4/24 





要 设置 超 链接 
?pageno-". ($pageno+1) ."> 下 一 页 





前 页 不 是 最 后 页 时 ， 对 “上 一 页 ”要 设置 超 链接 
Smsg.="<a href-".$ SERVER['PHP SELF']."?pageno-". ($1astp)."» 最 后 页 </a> "; 
else $msg. ; // 当 前 页 是 最 后 页 时 ， 不 要 设置 超 链接 
/ /设置 分 页 显 放 
$title=" 会 员 购 书 卡 查询 "; ”// 设 逢 当前 页 的 标题 
include ("memhead.php"); // 包 含 头 部 
?> 











<div id="bt"> 会 员 购书 卡 查询 <hr /></div> 
«div id="bd"> 
«formname-"frm" action="<?php echo $ SERVER['PHP SELF']?»?pageno-«?php 
echo $pageno; ?»"method-"post"» 
«table width-"100$" border-"0" cellspacing-"0"» 
<tr id-"err"»«td»«?php echo $userid.":  ".$infostr;?»«/td» <!-- 状 
态 栏 --> 
<tdalign="right"> 输入 页 次 : 
«input type-"submit 
«/tr» <!-- 状 态 栏 -- 
</table> 


</form> 


«input type="text" size="3" name= "pageno"» 
Ha" /»«/td» 





"goto" value= 





«table width-"100$" border-"1" cellspacing-"1"» 
«tr id-"err" align="center"><td> 序 号 </td><td> 卡 号 </td><td> 余 额 
</td><td> 等 级 </td><td> 密 码 </td><td> 有 效 日 期 </td></tr> 
«?php 
$i-1; // 读 取 指定 会 员 号 的 卡号 信息 
while($row-mysql fetch array ($records))( 
$cardno[$i]-$row['cardno']; 
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$i++; 

} 

for ($i=$numf; $i<=$numl; $i++) { // 显 示 当 前 页 的 购书 卡 信 
$sql3="SELECT * FROM card WHERE cardno-'".$cardno[$i] 





$records3-mysql query ($sql3); // 查 询 指定 卡号 的 购书 卡 信息 
$row2-mysql fetch array($records3); 


$dbdate-$row2['ctime']; // 获 取 购 书 卡 生成 日 期 
$year=substr ($dbdate, 0,4); // 获 取 字符 串 中 的 年 
$month-substr ($dbdate, 5,2) ; // 获 取 字 符 串 中 的 月 
$day-substr ($dbdate, 8,2); // 获 取 字 符 串 中 的 日 


".$month." 月 ".$day." 日 "; ”// 生 成 购书 卡 的 有 效 期 

echo "<tr id-'bd' align-'center'»«td»NO.".$i."«/td»"; 

echo "«td»&nbsp;".$row2['cardno']."«/td»«td»&nbsp;".$row2['balance']." 
JU«/td»«td»&nbsp; ".$row2['cardlevel']."«/td»"; 

echo "«td»&nbsp;".$row2['cardpsd']."«/td»«td»&nbsp; ".Stime."«/td»«/tr»"; 


$time-($year*2)."4 





?» 
«tr aligns"center"»«td colspan-z"6"» 





«form action-"applycard.php" method-"post"»«input type-"submit" 
name-"send" value=" 申 请 购书 卡 "></form> 


</td></tr> 
</table> 
«div id-"err" align="center"><?php echo $msg; ?> </div> <!-- 翻 页 导航 
栏 --> 
«div id="err"><?php echo $errmsg; ?></div> 
</div> 
<hr/> 


<iframe scrolling="no" width="780" height-"70" src-"membottom.html" 
marginwidth-"O"marginheight-"0" border-"0" frameborder-"0" align= "center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 





(3) 把 文档 以 usercard.php 为 文件 名 保存 在 member 文件 夹 下 。 


Miragi 


段 代码 中 的 上 半 部 分 是 PHP 处 理 ， 下 半 部 分 是 页 面 显示 。 各 行 中 的 含义 见 其 后 的 注释 。 此 处 对 代 
码 段 的 功能 做 些 注解 。 

第 3 一 8 行 : 初始 化 变 

第 6 一 8 行 : 页 面 中 获取 当前 页 的 值 的 方式 有 两 种 : 一 是 从 URL 传递 ; 二 是 由 用 户 在 状态 栏 处 输 
入 数值 ， 然 后 按 “ 跳 到 ”按钮 提交 ， 这 里 给 出 了 一 个 判断 。 

第 9 一 11 行 : 连接 数据 库 ， 设 置 查询 SQL， 查 询 数据 表 usercard 中 指定 会 员 号 的 信和 

第 12 一 15 行 : 数据 表 usercard 中 无 指定 会 员 号 的 信息 ( 即 用 户 没有 申请 过 购书 卡 ) 的 处 理 。 设置 反馈 
息 ， 重 定向 到 页 面 applycard.php. 
第 17 一 79 行 : 对 申请 过 购书 卡 的 会 员 的 处 理 。 本 段 变 量 及 其 含义 如 表 5.12 所 示 。 


M 
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表 5.12 usercard.php 中 用 到 的 变量 及 其 含义 



































变 量 名 m fü & x 
Stotal 自 定义 变量 。 记 录用 户 拥有 的 总 记录 数 
Slastp 自 定义 变量 。 记 录 分 页 显示 的 最 后 一 页 的 页 码 
Spageno 自 定义 变量 。 记 录 当 前 页 的 页 码 
Spagemax 自 定义 变量 。 在 opendata.php.inc 定义 的 记录 每 页 显示 记录 数 
Sinfostr 自 定义 变量 。 记 录 状 态 栏 上 的 信息 
Snumf 自 定义 变 最。 记录 当前 页 的 第 一 条 记录 对 应 的 记录 
Snuml to 记录 当前 页 的 最 后 一 条 记录 对 应 的 记录 
Smsg 记录 分 页 显示 的 翻 页 导航 栏 
Scardno[Si] 自 定义 变量 。 记 录用 户 所 拥有 的 购书 卡 的 卡号 





$ SERVER[PHP SELF] 
Stitle 





预定 义 全 局 变量。 获取 当前 正在 执行 脚本 的 文件 名 
变量 。 页面 的 标题 





Serrmsg 。 记 录 反 馈 信息 
Suserid 。 记录 用户 的 会 员 号 








$ SESSION['userid'] 预定 义 全 局 变量 。 记 录 SESSION 变量 userid 的 值 











$sql, Ssql2 SQL 命令 o ER SQL 命令 
Srecords, $records2 查询 数据 集 s 记录 执行 SQL 命令 后 的 返回 结果 
Srow. $row2 字符 串 自 定义 数组 变量 。 记 录 查 询 数据 集中 当前 行 各 字段 的 数据 


第 17 一 26 f: 设置 状态 栏 信 息 % 需要 计算 总 记录 数 、 总 页 教 5 当前 页 码 和 当前 页 显示 的 起 始 记 录 。 
第 27 一 36 行 : 设置 分 页 显示 的 翻 页 导航 栏 。 需要 根据 当前 页 是 否 首页 或 尾 页 来 设置 超 链接 。 链接 
的 位 置 是 对 当前 页 面 指定 的 分 页 。 

第 41 一 52 行 : 显示 页 内 标题 和 以 表格 方式 显示 用 户 购书 卡 信息 的 表 头 。 

第 43 一 52 行 :< 设置 表单 。 表 单 处 理 程序 为 对 指定 的 分 页 的 当前 页 面 ， 

P 45—46 行 ; 设置 状态 栏 。 其 中 的 表单 包含 文本 框 ， 允 许 用 户 指定 页 码 。 
第 54 一 58 行 : 分 别 读 取 会 员 的 购书 卡号 ， 以 便 在 分 页 显示 时 分 页 提取 相应 的 购书 卡 信息 。 
第 59 一 71 行 : 显示 分 页 的 用 户 购书 卡 信息 。 

第 60 一 70 行 : 提取 本 页 需要 显示 的 记录 并 显示 在 对 应 的 表格 中 。 

第 63 一 67 £r: 根据 卡 的 生成 日 期 ， 生 成 卡 的 使 用 有 效 期 。 其 中 函数 substr() 为 字符 串 函 数 。 





string substr(string string, int start [, int length]) 
功能 : 返回 由 start 开始 指定 长 度 length 的 部 分 字符 串 。 
说 明 : 没有 参数 start， 返 回 字符 串 从 0 开始 :没有 参数 length， 返 回 字符 串 到 末端 。 




















第 74 行 : 设置 表单 ， 只 包含 “申请 购书 卡 ” 按 钮 ， 设 置 用 户 申 请 新 卡 的 入 口 ， 处 理 程序 为 applycard.php. 
第 77 行 : 显示 分 页 显示 的 翻 页 导航 栏 。 
第 78 行 : 显示 反馈 提示 信息 。 


(4) 新 建 PHP 文档 。 
(5) 单 击 “ 代 码 ” 标 签 ， 


切换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
$errmsg=""; 
if(isset($ GET['errmsg'])) $errmsg=$ GET['errmsg']; 
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游 
ul 
qt 
n» 
B 





$title=" 购 书 卡 申请 "; 
include once ("memhead.php"); 
?» 


«script languag 





'"JavaScript"» 
function jcidd()( 
var idss-window.frm.cardno.value; 
var cds-window.frm.password.value; 
var pds-window.frm.password2.value; 
if (idss--"")( 
window.alert ("购书 卡号 不 





A"): 
window.frm.cardno.focus(); 

) 

else if(idss.length«4 || pds.length»30)[( 
window.alert ("购书 卡号 长 度 不 合法 , 请 重新 输入 "); 
window.frm.cardno.value-""; 
window.frm.cardno.focus(); 

) 

else if (cds 





wo 
window.alert (" 购 





3 不 能 为 空 ") ; 
window.frm.password.focus(); 

) 

else if (cds.length«6 || cds.length»20)( 
window.alert (" 购 码 长 度 不 合法 , 请 重新 输入 ") ; 
window.frm.password.value= 








window.frm.password.focus(); 
) 
else if (pds!-cds)( 
window.alert ("lij 











3 两 次 输入 不 匹配 ") ; 


window.frm.cpassword2.focus(); 






) 
) 
</script> 
<div bt"> 购 书 卡 申请 <hr /></div> 
<div bd"> 
<div id="err"><?php echo $_SESSION['userid']; ?>-> 正 在 申请 购书 卡 </div> 


«form action-"applycard P.php" method="post"> 
«table width-"100$" border-"0" cellspacing-"0" class-"tdl"» 
<tr><td width="30%"align="right"> 输 入 购书 卡号 </td><td><input type= 
"text" name-"cardno" size="30"/> (位 数 4~30， 必 须 由 字母 与 数字 组 成 ) </td></tr> 
<tr><td align="right"> 输 入 购书 卡 密码 </td><td><input type="password" 
name="password"size="20"/> (位 数 6 一 20， 必 须 由 字母 与 数字 组 成 ) </td></tr> 
<tr><td align="right"> 确 认购 书 卡 密码 </td><td><input 


type-"password" name-"password2" size="20"/></td></tr> 








<tr><td align-"center"colspan-2»«input type="submit" 
name-"sendapp" value=" 确 定 " onmousedown- "jcidd()"» 





<input type="submit" name-"sendapp" value=" 跳 过 "></td></tr> 
</table> 
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«/form» 
«div id-"err" align-"center"»«?php echo $errmsg; ?»«/div» 








-> 
</div> 

<hr/> 

<iframe scrolling="no" width="780" height="70" src="membottom.html" 
marginwidth ="0"marginheight="0" border-"0" frameborder-"0" align-"center" > 
不 支持 </iframe> 

</div> 

</body> 

</html> 


(6) 把 文档 以 applycard.php 为 文件 名 保存 在 member 文件 
(7) 新 建 PHP 文档 





(8) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
<?php 
Gsession start(); // 获 取 SESSION 的 userid 值 
$sendapp=$_POST['sendapp']; $cardno-$ POST['cardno']; 
$password-$ POST['password']; // 获 取 提 交 的 表单 数据 
$userid=$ ir cien 'userid']; 
if ($sendapp==' 确 定 ' // 单 击 “ 确 定 ” 按 钮 的 处 理 


PN UP NN // 连 接 数 据 库 ， 查 询 数据 表 card 
$query-"SELECT * FROM card WHERE cardno-'$cardno'"; 
$result-émysgl query ($query,$connection) or die(" 浏 览 失 败 ! 2"); 
if ($row=mysql_fetch_array ($result)){ // 数 据 表 card 中 存在 用 户 输入 的 卡号 
if ($row[cardstatus]--"N")( // 卡 号 状态 不 可 用 
Serrmsg=" 该 卡 不 能 使 用 ! "; 
echo "<meta http-equiv-'Refresh' content='0;url=applycard.php? 





errmsg- Serrmsg'»"; 


) 
elseif(Srow['cardpsd']--$password)( // 卡 号 状态 可 用 且 用 户 输入 的 密码 正确 


$errmsg=" 申 请 成 功 ! "; 
Squery-"INSERT INTO usercard (userid,password,cardno) VALUES 


('$userid', '$password','$cardno')"; 
$result-8mysgl query ($query, $connection) or die ("浏览 失败 ! 2") ; 
$query-"UPDATE card SET cardstatus-'N' WHERE cardn $cardno'"; 
$result-8mysql query ($query, $connection) or die ("浏览 失败 ! 2") ; 


echo "«meta http-equiv-'Refresh' content-'0;url-usercard.php? 






errmsg- Serrmsg& pageno-1'»"; 
) 
else( // 卡 号 状态 可 用 且 用 户 输入 的 密码 不 正确 
$errmsg=" 密 码 错误 ， 请 重新 输入 ! "; 
echo "<meta http-equiv-'Refresh' content='0;url=applycard. php? 
errmsg=$errmsg'>"; 


} 





第 S 章 会 员 注册 和 管理 设计 与 数据 获取 


else( // 数 据 表 card 中 没有 用 户 输入 的 卡号 
$errmsg=" 不 存在 该 卡号 ， 请 重新 输入 "; 
echo "<meta http-equiv-'Refresh' content='0;url=applycard.php? 
errmsg-$errmsg'»"; 
H 


) 
elseif ($sendapp==' 跳 过 ') header("Location:memindex.php"); 





Ct 


(9) 把 文档 以 applycard_P.php 为 文件 名 保存 在 member 文件 夹 中 。 


e. aos 


第 6 一 32 行 : 单 击 “ 确 定 ” 按 钮 时 的 处 理 ， 其 中 
第 7 一 9 行 : 连接 数据 库 ， 查 询 数据 表 card 中 用 户 指定 的 卡号 > 
第 10 一 27 47: 对 数据 表 card 中 存在 用 户 指定 的 卡号 的 处 理 。 
第 11 一 14 行 : 数据 表 card 中 指定 的 卡号 状态 不 可 用 。 设置 反锁 信息 Smsg; 刷新 页 面 applycard:php， 
同时 传递 反馈 信息 Smsg.。 
第 15 一 26 行 : 数据 表 card 中 指定 的 卡号 状态 可 用 .其 中 
第 16 一 21 行 : 用 户 输入 的 购书 卡 密码 正确 。 设置 反馈 信息 $errmsg; 修改 相关 信息 ; 刷新 页 
面 usercardcard.php， 同 时 传递 反馈 信息 Serrmsg。 其 中 
第 17 一 18 行 : AP HRE userid,password,cafdno) 插 入 数据 表 usercard 中 。 
第 19 一 20 行 : 修 收 数据 表 card 中 卡 的 状态 (cardstatus) 为 不 可 用 (N). 
第 23 一 26 行 : 用 户 输入 的 购书 卡 密码 不 正确 设置 反馈 信息 $msg; 刷新 页 面 applycard.php， 
同时 传递 反馈 信息 Smsg。 
第 28—31 行 :数据 表 card 中 没有 用 户 输入 的 卡号 > 设置 反馈 信息 Smsg; 刷新 页 面 applycardphp， 同 时 
竺 递 反馈 信息 $msg， 
第 334r: 单 击 飞 跳 过 ”按钮 时 的 处 理 。 重 定向 页 面 memindex.php. 


5.4.6 会 员 修改 资料 页 与 处 理 程 序 
代码 文件 ，modify.php、update.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
?php 

$userid=$_SESSION['userid']; 

$password-$ SESSION['password']; 





Sisnew-0; // 设 置 反馈 信息 自 定义 变量 
if(isset($ GET['isnew'])) Sisnew-(int)$ GET['isnew']; 
$succend-0; 





if(isset($ GET['succend'])) $succend-(int)$ GET['succend']; 
Serrmsg-""; 


if(isset($ GET['errmsg'])) $errmsg=$ GET['errmsg']; 
if ($isnew==0) { // 获 取 用 户 的 资料 
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require_once ("opendata.php. inc"); 

$sql="SELECT * FROM userinfo WHERE userid='$userid'"; 
$records-mysql query ($sql); 

$rows=mysql fetch array($records); 
$username-$rows['username']; 

$email-S$rows['email']; 

$addr-$rows['addr']; 

$phone-$rows['phone']; 

$post-$rows['post']; 


=""; $post-z""; $phone-""; } 





include ("memhead.php"); 
?» 
«script language-"javaScript" type-"text/javascript'» // 客 户 端 用 户 输入 的 有 效 性 检查 


function pdsr()( 
var pds-window.frm.password.value; 
var pdsl-window.frm.confirml.value; 
var ph-window.frm.phone.value; 
if(pds.length«6 || pds.length»?20)| 
window.alert (" 密 码 长 度 不 合法 ,请 重新 输入 ") ; 
window.frm.password.value- 








window.frm.password.focus(); 
) 
else if(pds!-pdsl)( 
window.alert ("确认 密码 , 请 再 次 输入 "); 
window.frm.confirml.value- 





window.frm.confirml.focus(); 
) 
else if(ph.length«8 || pds.length»15)( 
window.alert(" 电 话 长 度 不 合法 ,请 重新 输入 ") ; 
window.frm.phone.value-""; 
window.frm.phone.focus(); 


) 
</script> 
«div id="bt"> 修 改 会 员 申 请 资料 <hr /></div> 
<div id="bd"> 
«div id-"err" align="center"> 带 &nbsp;*&nbsp; 的 选项 是 必须 填写 的 </div> 
<form action="update.php" method="post" name="frm"> 
«table width-"100$" border="0" cellspacing="0" class-"tdl"» 
<tr><td align="right"> 会 员 号 </td> <td><input name-"userid" type= "text" 
disabled-"disabled" value-"«?php echo $userid; ?>" size-"40" /> </td></tr> 


«tr»«td align="right"> 姓 名 </td><td><input type-"text" size-"40" 





name-"username" valu 





<?php echo $username; ?»"/»«/td»«/tr» 
"right"»Email«/td»«td»«input typ 
name-"email" value-"«?php echo $email; ?»"/»«/td»«/tr» 





«tr»«td align text" size-"40" 





第 S 章 会 员 注册 和 管理 设计 与 数据 获取 


<tr><td align="right"> 会 员 密码 «/td»«td»«input type="text" name= 
"password" size-"40"value-"«?php echo $password; ?>"/> &nbsp;*&nbsp; 
&nbsp; (密码 位 数 6 一 20， 必 须 由 字母 与 数字 组 成 ) «/td»«/tr» 
<tr><td align="right"> 再 次 输入 密码 </td> “<“!-- 输 入 两 次 密码 以 确保 修改 密码 无 误 --> 
<td><input type-"text" size-"40" name-"confirml" value-"«?php echo 
$password; ?>" /»&nbsp;*&nbsp; &nbsp; </td></tr> 
<tr><td align="right"> 邮 编 </td><td><input type-"text"size-"20" 
name-"post" value-"«?php echo $post; ?>"/></td></tr> 
<tr><td align="right"> 地 址 </td><td><input type="text" name-"addr" 
size="80" value-"«?php echo $addr; ?>"/></td></tr> 
<tr><td align="right"> 电 话 号 码 </td><td><input type-"text" name-"phone" 
size="20" value-"«?php echo phone; ?»"»&nbsp; *&nbsp; &nbsp; </td></tr> 
<?php if($succend!-1)(  //4&pk X Ja Brill F MRAR ?> 
<tr><td colspan-"2" align-"center"»«input name-"sendup" 
type="submit" value=" 人 确认 提交 "” onmousedown-"pdsr()"»&nbsp;&nbsp;«input 
name-"sendup" type="submit" value=" 重 新 填写 "></td></tr> 
<?php } ?> 
</table> 
</form> 
«div id="err" align="center"><?php echo $errmsg; ?></div> 
</div> 
<hr/> 
<iframe scrolling-"no" width-"780" height="70" src-"membottom.html" 
marginwidth-"0" marginheight-"0" border-"0" frameborder-"0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 








(3) 把 文档 以 modify.php 为 文件 名 保存 在 member 文件 夹 中 。 


d &28 


这 段 代码 的 结构 与 前 两 段 类 似 。 PHP 处 理 的 是 根据 变量 Sisnew 确定 是 否 在 表单 的 文本 框 中 显示 数 
据 库 中 存储 的 用 户 资料 。 
第 4 一 9 行 : 初始 化 变量 Sisnew、S$succend、Serrmsg 的 值 。 若 以 GET 方式 传递 ， 就 获取 它 。 
第 10 一 20 £r: $isnew=0 的 处 理 ， 即 提取 数据 库 中 有 关 userid 的 数据 。 
第 21 行 : Sisnew-l 的 处 理 ， 即 设置 除 userid 和 password 以 外 的 用 户 数据 为 空 。 
第 25 一 46 行 : 使 用 JavaScript 对 用 户 输入 进行 有 效 性 检查 (密码 输入 的 合法 性 ， 确 认 密码 输入 ， 电 话 
输入 的 合法 性 )。 对 邮箱 数据 的 合法 性 检查 可 通过 正则 表达 式 实现 ， 详 见 第 8 章 。 
第 50—65 行 : 表单 处 理 程序 update.php， 表 单 以 POST 方式 提交 ， 文 本 框 的 值 为 数据 库 中 相应 的 数 
dg. 其 中 
第 52 行 : 会 员 号 文本 框 为 禁用 ， 不 允许 修改 . 
$55. 57. 6041: 用 户 最 可 能 修改 的 资料 ,文本 框 中 显示 相应 的 数据 ， 减 少 用 户 输入 ， 若 改变 
了 ， 需 要 确认 输入 的 合法 性 和 有 效 性 ， 这 由 第 30~44 行 的 JavaScript 处 理 ， 
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第 61 一 63 行 : 选择 是 否 显示 下 面 的 按钮 。 如 果 成 功 ， 修 改 就 隐藏 . 
第 62 行 : 两 按钮 的 name 都 是 sendup， 以 便 在 update.php 获取 并 对 它们 分 别处 理 。 





(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(5) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
«?php 

Suserid-$ SESSION['userid']; 

Susername-$ POST['username']; 














$password-$ POST['password']; 
$addr=$ POST['addr']; 
$email-$ POST['email']; 
$post-$ POST['post']; 
$phone-$ POST['phone']; 








$sendup-$ POST['sendup']; 
$sqll-""; 
if ($sendup==" 重 新 填写 ") header ("Location:modify.php?isnew-1"); // 页 面 重 定向 


if ($sendup==" 确 认 提交 ") { ”// 单 击 “ 确 认 提交 ”按钮 后 的 处 理 

if(Semail!-"") $sqgll.-",email-'$email'"; 

if($username!-"") $sqll.-", username-'$username'"; 

if(S$addr!-"") $sqll.=", addr-'$addr'"; 

if(Spost!-"") $sqll. post-'$post'"; 

if($phone!-"") $sgll.-", phone-'$phone'"; 

require once ("opendata.php.inc"); 

$sql-"UPDATE userinfo SET  password-'$password'".$sqll." WHERE 
userid-'$userid'"; 

mysql query ($sql); 

mysql close(); 

S$errmsg=$userid." 修 改 信息 : ”恭喜 你 ， 你 已 经 完成 了 个 人 资料 的 修改 ! "; / /设置 反馈 信息 


header ("Location:modify.php?succend-1&isnew-0&errmsg-".$errmsg); 





?> 


(6) 把 文档 以 update.php 为 文件 名 保存 在 member 文件 夹 中 。 


\ us 
段 代码 实现 更 新 用 户 修改 的 数据 。 
第 10 行 : 自 定义 变量 $sqll 记录 需要 更 新 的 字段 。 
第 11 行 : 单 击 “ 重 新 按钮 时 ， 以 Sisnew=] 方式 重 定向 到 页 面 modify.php. 
第 12 一 24 行 : 对 当 用 户 单 击 了 “确认 提交 ”按钮 后 的 处 理 。 
第 13 一 17 行 : 设置 需要 修改 的 字段 。 用 户 单 击 “重新 填写 ”按钮 后 ， 没 有 输入 即 视 为 不 修改 。 
第 18 一 20 行 : 连接 数据 库 ， 更 新 需要 修改 的 数据 ， 关 闭 数 据 库 连 接 。 
第 23 行 : 以 Sisnew=1 和 S$succend=] 方式 重 定向 到 页 面 modify.php， 同 时 传递 反馈 信息 $msg。 
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密码 页 与 处 理 程序 





代码 文件 : forget.php、search.php 





(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 切换 到 “代码 ” 


«?php 
Gsession start(); 
$useri SESSION['userid']; 
Serrmsg-"";$ok-0 ; // 初 始 化 自 定义 变量 。$ok 记录 是 否 成 功 地 查询 到 了 密码 
if(isset($ GET['ok'])) $ok=$_GET['ok']; // 如 果 $ok 的 值 以 GET 方式 传递 就 
获取 它 作为 当前 $isnew 的 值 











视图 ， 输 入 如 下 代码 。 








if(isset($ GET['errmsg'])) ( 
if ($ok==0) $errmsg-$ GET['errmsg']; 
else Serrmsg-"Suserid: 您 的 密码 为 :<font color-red»".$ GET['errmsg']." 
</font>"; 
} 
$title=" 





Ua ri"; 
include ("memhead.php"); 
?» 
«div id-"bd"» 
«div id="bt"> 密 码 查询 一 输入 住址 或 者 电子 邮件 账号 <hr /»«/div» 
<?php if($ok==0){ ?> <!-- 查 询 成 功 后 隐藏 表单 --> 
<form action-"search.php" method="post"> 
«table width-"100$" border-"0" cellspacing-"0" class-"tdl"» 
<tr><td width-"30$" align="right" > 输入 E-mail</td><td><input 
type- "text" name- "email" size-"30" /»«/td»«/tr» 
<tr><td align="right" class="tdl"> 输 入 住址 </td><td><input type= 
"text" size-"60" name-"addr" /></td></tr> 
<tr><td aligi center"colspan-2 class-"tdl"»«input type="submit" 
name-"send" value-"frifj" </td></tr> 
</table> 
</form> 
<?php ) ?> ”<!-- 查 询 成 功 后 隐藏 表单 --> 
<div id="err" align="center"><?php echo $errmsg; ?></div> 
</div> 
<hr/> 
<iframe scrolling-"no" width="780" height="60" src-"membottom.html" 
marginwidth="0" marginheight="0" border= 
"center" > 不 支持 </iframe> 
</div> 
</body> 
</html> 


(3) 把 文档 以 forget.php 为 文件 名 保存 在 member 文件 夹 中 。 
(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 














" frameborder="0" align= 
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(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
@session start(); 
$userid=$ SESSION['userid']; 
require_once ("opendata.php.inc"); 
$email=$ POST['email']; 
$addr=$ POST['addr']; 
$ok=0; 
" && $addr==""){ 
清 输 入 地 址 或 者 电子 邮件 账号 ! n7 
header ("Location:forget.php?errmsg=$errmsg"); 
) 
if(S$email«»"")( 
$sql1-"SELECT * FROM userinfo WHERE (email-'$email' && userid-'$userid')"; 
$records-mysql query ($sql); 











Serrmsg- 






if ($email== 
$errmsg= 


$rows-mysql fetch array($records); 
if(mysql num rows ($records)--1)( 
Serrmsg-$rows [password]; 
$ok-1; 
) 
else Serrmsg- 





法 按 您 的 输入 找到 您 的 密码 , 请 检查 输入 是 耕 有 误 !! <br/> 请 重新 输入 "; 
header ("Location:forget.php?errmsg=$errmsg&ok=$ok"); 

} 

elseif ($addr<>""){ 
$sql="SELECT * FROM userinfo WHERE (addr-'$addr' && userid- 'Suserid')"; 
$records-mysql query ($sql); 





$rows2-mysql fetch array($records); 
if(mysql num rows ($records)--1)( 
Serrmsg-$rows2 [password]; 
$ok-1; 
) 
else $errmsg=" 无 法 按 您 的 输入 找到 您 的 密码 , 请 检查 输入 是 否 有 误 !! <br/> 请 重新 输入 "; 
} 
header ("Location:forget.php?errmsg-$errmsg&ok-$ok"); 
?» 


(6) 把 文档 以 search.php 为 文件 名 保存 在 member 文件 夹 中 





人 
Mrapi 


本 段 代 码 实 现 对 查询 输入 的 处 理 。 用户 只 要 输入 E-mail 或 住址 都 可 以 查询 到 密码 。 

第 8 一 11 行 : 没有 输入 任何 信息 就 单 击 了 “查询 ”按钮 。 设置 反馈 信息 并 重 定向 到 页 面 forget.php. 

第 12 一 22 行 : 输入 了 E-mail 的 处 理 。 查询 数据 表 userinfo 中 该 会 员 的 E-mail， 符合 就 标识 查 到 了 Sok=1， 
不 符合 也 设置 反馈 以 ok 的 方式 (=1 时 隐藏 表单 ) 重 定向 到 页 面 forget.php. 

第 23 一 32 行 : 输入 了 住址 的 处 理 。 与 输入 了 E-mail 的 处 理 类 似 。 
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第 33 行 : 重新 定向 显示 forget.php 页 ， 并 以 GET 方式 传递 Serrmsg 和 S$ok. 
5.4.8 ”购书 卡 管理 页 与 处 理 程序 


代码 文件 : managerphp、card_p.php、addcard.php、updatecard.php、updatecardp.php、 
delcard.php 

(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 

$pageno-1;S$errmsg-"";S$dd-array(); 

if(isset($ GET['pageno'])) ( 

$pageno-(int)$ GET['pageno']; 
if(isset($ POST['pageno'])) $pageno-(int)$ POST['pageno']; 

) 

if(isset($ GET['errmsg'])) Serrmsg-$ GET['errmsg']; 

require ("opendata.php.inc"); 

$sql-"SELECT * FROM card"; 

$records-mysql query ($sql); 

// 设 置 分 页 显示 开始 

$total=mysql num rows ($records); 

Slastp-ceil(S$total/Spagemax); 

$infostr=" 目 前 共有 «font color=red>". $total."«/font» 张 购书 卡 ， 共 «font 
color-blue»" .$1astp." </font> Jt, "; 

if ($pageno»$lastp) Spageno-$lastp; 

elseif ($pageno<1) S$pageno-1; 

$numf- ($pageno-1) *$pagemax*1; 

$numl-$numft$pagemax-1; 

if ($numl>$total) S$numl-$total; 

$infostr.=" 本 页 是 第 «font color=red>" .$pageno. "</font> W, "; 
刚 出 了 第 «font color=red>" .Snumf."</font> fj"; 
Sinfostr.-" «font color=red>".$numl."</font> 条 记录 。" 
if($pageno!-1) $msg-"«a href=manager.php?pageno=1> 第 1 页 </a> "7 


$infostr. 









else $ms $13; 

$msg.-" | "; 

if($pageno»1l)  $msg.-"«a href-manager.php?pageno-". ($pageno-1)."» 上 一 页 
am 

if ($pageno<$lastp) $msg.-"«a href-manager.php?pageno-".($pageno*l)."» F 
= |"; 


if($pageno!-$1astp) $msg.-"«a href-manager.php?pageno-".($lastp)."» 
最 后 一 页 </a> "; 

else $msg.=" 最 后 页 "; 

// 设 置 分 页 显示 结束 

$title=" 购 书 卡 管理 "; 

include ("memhead.php"); 
m 
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«div id="bt"> 购 书 卡 管理 smdash; smdash; 查询 <hr /></div> 
<div id="bd"> 
«formaction-"manager.php?pageno-«? echo $pageno; ?>" method="post"> 
<table width-"100$" border-"0" cellspacing-"O0" class-"tdl"» 
«tr id-"err"»«td»«div»«?php echo $infostr;?»«/div»«/td» 
<td align="right"> 输入 页 次 : «input type="text" size-"3" name= 





"pageno"» 
<input type="submit" value=" 转 到 " /»«/td»«/tr» 
</table> 
</form> 





<form action="card p.php?pageno= 
«table width="100%" border-"1" cellspacing-"1" class-"tdl"» 
«tr id-"err" align-"center"»«td > 选中 </td><td> 卡 号 </td><td align= 
"center"> 余 额 </td> 
<td> 等 级 </td><td> 是 否 可 用 </td><td> 有 效 日 期 </td></tr> 


?php echo $pageno; ?>" method- "post"> 


«?php 
$sql-2"SELECT * FROM card WHERE (serial»-'$numf' AND serial«-'$numl')"; 
$records-mysql query($sql); 
while(list($cserial, Scno,, S$cbalance, $clevel, $cstatus, $cctime)- 

mysql fetch row($records))( 

$dbdate-Scctime; 

$year-substr ($dbdate, 0,4); $month-substr ($dbdate, 5,2); $day- substr 
($dbdate, 8,2) ; 

$time= ($year+2) ." 年 " 





$month."H".$day."H"; 

echo "<tr align-'center'»«td»«input type-'checkbox' name= 'd[".$cserial."] 
' valuez'del'»"; 

echo "&nbsp;NO.".$cserial."«/td»"."«td»".S$cno."«/td»«td»".S$cbalance." 
</td>"; 

echo "<td>".$clevel."</td><td>".$cstatus."</td><td>". $time."</td></tr>"; 


<tralign="center"><td colspan="6"><input type="submit" name="send" 
value=" 删 除 ">&nbsp; snbsp;<input type="submit" name=" 加 
">&nbsp; &nbsp; <input type="submit" name-"send" value=" 充 值 " /»«/td»«/tr» 
</table> 
</form> 


end" value= 





<div id="err" align="center"><?php echo "$msg"; ?></div> 
<div id="err" ><?php echo $errmsg; ?></div> 
</div> 
<hr/> 
<iframe scrolling="no" width-"780" height="70" src-"membottom.html" 





marginwidth="0" marginheight-"0" border=" 
不 支持 </iframe> 
</div> 
</body> 
</html> 


" frameborder-"0" align-"center" > 
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(3) 把 文档 以 manager.php 为 文件 名 保存 在 member 文件 夹 中 。 


Muss 


段 代码 实现 分 页 显示 数据 表 card 中 所 包含 的 所 有 记录 。 与 usercard.php 类 似 。 
第 43 行 : 设置 表单 ， 包 含 “添加 ” “充值 8 和“ 删除” 按钮， 处理 程序 是 card_p php。 





第 48 行 : 设置 SQL 语句 。 由 于 数据 的 来 源 是 数据 表 card， 提 取 的 记录 数 就 是 每 页 显示 的 行 数 ， 因 
此 查询 记录 范围 限制 在 每 页 的 首尾 行 。 
第 50 行 : 


向 表格 输出 每 行 的 数据 。 使 用 list( ) 函 数 来 提取 数组 mysql fetch row($records) 中 对 应 的 数据 。 
void list(mixed .)  // mixed 指数 据 可 以 是 记录 类 型 (不 一 定 是 同一 数据 类 型 ) 
功能 :list( ) 用 一 步 操作 给 一 组 变量 进行 赋值 (从 最 右边 一 个 参数 开始 赋值 )。 

W: 像 array( ) 一 样 ， 这 不 是 真正 的 函数 ， 而 是 语言 结构 。 


数组 mysql_fetch_row($records) 中 key 445i f 7 (serial,cardno,cardpsd,balance,cardlevel,cardstatus,ctime), 
依次 赋值 给 ($cserial,$cno,,Scbalance,$clevel,$cstatus,Scctime)， 由 于 不 需要 密码 ， 因 此 列表 中 在 $cno 和 
Scbalance 之 间 留 出 了 空位 。 
第 54 行 : 使 用 数组 获取 复 选项 的 数据 收集 。 当 选中 某 个 复 选 框 时 ， 其 对 应 的 值 就 是 del， 对 应 的 下 
标 是 $cserial， 这 样 就 能 断定 所 选中 的 行 了 ; 没有 被 选中 复 选 框 ， 其 值 为 空 。 
(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(5) 单 击 “代码 ”标签 ， 切 换 到 交代 码 ” 视 图 ， 输 从 如 下 代码 。 
«?php 
session start(); 
$pd-$ POST["send"]; 
if($pd==' 添 加 ') header("Location:addcard.php"); 
else{ // 单 击 其 他 两 个 按钮 的 处 理 
$pageno=$ GET["pageno"]; 
$dd=$_POST["d"]; 
$num=count ($dd) ; 
if($num--0)( 
$errmsg=" 必 须 选 中 一 个 购书 卡 ! <br/>"; 


header ("Location:manager.php?pageno=$pageno&errmsg=$errmsg"); 
} 
else( 

if(!isset($ SESSION['de1'])) 
$ SESSION['del']-$dd; 
if($Spd==' 充 值 ') header ("Location:updatecard.php?pageno-$pageno"); 
else if ($pd==' 删 除 ') 


$ SESSION['del']-array(); 


header ("Location:delcard.php?pageno-$pageno"); 





(6) 把 文档 以 card. p.php 为 文件 名 保存 在 member 文件 夹 中 。 
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e 


Miragi 


本 段 代码 实现 对 管理 员 单 击 按钮 的 分 类 处 理 .“ 添 加 ”操作 不 需要 选中 已 经 存在 的 某 张 卡 ， 但 “充值 ” 
和 “删除 ”操作 前 需要 先 选中 至 少 一 张 购书 卡 . 这 样 ， 表 单 的 处 理 程序 必须 对 3 个 按钮 的 处 理 页 面 作出 选 
择 。 获取 的 复 选 数 据 可 能 会 在 多 个 页 面 间 传 递 ， 定 义 一 个 $_SESSION 数组 来 存储 它们 。 
第 6 行 : 获取 分 页 显示 的 当前 页 码 。 这 个 数据 一 直通 过 GET 方式 在 页 面 间 传递 
第 7 行 : 提取 表单 数据 。 注 意 复 选 框 名 称 d 是 一 个 数组 。 
计数 组 中 所 含 数据 的 个 数 ， 就 能 了 解 用 户 是 否 选择 了 某 个 进一步 给 出 反馈 
信息 和 页 面 重 定向 
第 13 一 18 行 : 判断 是 否 已 经 创建 $S SESSION['del]， 和 否则 就 以 数组 方式 创建 它 ; 这 样 就 可 以 把 提取 的 
表单 数据 放 在 这 个 数组 中 ， 在 启动 会 话 的 页 面 中 使 用 刀 : 





第 8 一 12 行 





(7) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(8) 单 击 “ 人 代码” 标签， 切换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 
$msg-""; 
if(isset($ GET['msg'])) $msg-$ GET['msg']; 
if(isset($ POST['sendadd']))( 
$sendadd-$ POST['sendadd']; 
$cardno-$ POST['cardno']; 
$password-$ POST['password']; 
$balance-$ POST['balance']; 
) 
else $sendadd- 
if ($sendadd==' 确 定 添加 ') ( // 单 击 “确定 ”按钮 的 处 理 
switch ($balance) { 
case 2000: $cardlevel= 
case 1500: $cardlevel= 
case 1000: $cardlevel=" 银 卡 ";break; 
case 500: $cardlevel=" 普 通 卡 ";break; 









} 
require once("opendata.php.inc"); 
$sql="select * from card where cardno-$cardno"; 
$records-mysql query ($sql); 
if(mysql num rows($records)»0) $msg=" 购 书 卡 已 经 存在 ! 
else{ 
$sql="INSERT INTO card (cardno, cardpsd, balance, cardlevel, cardstatus) 
VALUES ('$cardno', '$password', '$balance', '$cardlevel','Y')"; 
Srecords=mysql query ($sql); 
Smsg=" 添 加 成 功 ! "; 
) 
echo "<meta http-equiv-'Refresh' content-'0;url-addcard.php?msg-$msg'-»"; 
) 
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else if(S$sendadd==' 返 回 ') header("Location:manager.php"); // 单 击 “ 返 回 ” 
按钮 的 处 理 
$title=" 购 书 卡 管理 emdash; smdash; 添 加 "; 
include ("memhead.php"); 
?2 
«script language-"javaScript" type-"text/javascript"» 
function pdsr()( 
var id-window.frm.cardno.value; 
var pds-window.frm.password.value; 
var blc-window.frm.balance.value; 





window.alert ("输入 购书 卡号 不 能 为 空 ") ; 
window.frm.cardno.focus(); 


) 


else if(pds--"")( 
window.alert (" 输 入 购书 卡 





HA f Ju 
window.frm.password.focus(); 





) 
else if(blc==""){ 
window.alert ("选择 购书 卡 类 型 ! "); 


window.frm.balance.focus(); 


) 
«/script» 
«div id="bt"> 购 书 卡 管理 smdash; smdash; 添 加 <hr /»«/div» 
<div id="bd"> 
<form name="frm" action="addcard.php" method="post"> 
«table width-"100$" border-"0" cellspacing-"0" class-"tdl"» 
<tr><td width="30%"align="right"> 输 入 购书 卡号 </td> 


<td> <input type="text" name="cardno" size="30"/></td></tr> 
«tr»«td align="right"> 输 入 购书 卡 密码 </td> 











<td><input type="text" name="password" size="20"/></td></tr> 
<tr><td align="right"> 选 择 购 书 卡 类 别 </td> 
<td><select name-"balance" size-"1"» 
<option value="500"> 普 通 卡 </option> 
«option value="1000"> 银 卡 </option> 
<option value="1500"> 金 卡 </option> 
<option value="2000"> 钻 石 卡 </option> 
</select></td></tr> 





<tr><td align="center"colspan=2> 


<input type="submit" name-"sendadd" value=" 确 定 添加 ” onmousedown 
="pdsr ()"/> 





<input type="submit" name="sendadd" value=" 返 回 "/> 
</table> 
</form> 











<div id="err" align="center"><?php echo $msg;?></div> 
</div> 
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«hr/» 
<iframe scrolling="no" width-"780" height-"60" src-"membottom.html" 
marginwidth-"0" marginheight-"0" border-"0" frameborder-"0" align-"center" » 
不 支持 </iframe> 
</div> 
</body> 
</html> 


(9) 把 文档 以 addcard.php 为 文件 名 保存 在 member 文件 夹 中 。 





本 段 代码 实现 对 购书 卡 的 添加 功能 。 前 面 的 PHP 程序 段 实现 对 表单 输入 提交 后 的 处 理 一 一 写 入 数据 
表 card， 后 面 的 HTML 实现 表单 和 反馈 boue 表单 处 理 程 序 为 自 处 理 ,， 返 回 页 面 managerphp 需要 
重 定向 ， 
第 12 一 17 行 : 数据 表 card 中 的 字段 cardlevel 记录 的 是 购书 卡 的 等 级 ， 根 据 金 额 balance 就 能 判断 。 
第 21 一 26 行 : 写 有 息 前 要 先 判 断 这 个 卡号 是 否 在 表 card 中 存在 . 插入 新 记录 就 是 对 表 中 
字段 的 赋值 。 两 种 情况 都 要 有 民 席 信息 。 
第 60—66 ff: 方便 管理 员 和 输入， 设置 下 拉 列 表 选 择 ， 但 各 选项 对 应 的 值 是 数值 ， 即 获取 的 是 金 宁 


Sbalance. 








(10) 在 Dreamweaver 中 新建 PHP 文档。 
(11) 单 击 “ 代 码 ” 标 签 , 切换 到 “代码 ”视图 ;输入 如 下 代码 。 


<?php 
@session start(); 
$errmsg="";$errmsg2="<br /»"; 
if(isset($ GET['errmsg'])) $msg-$ GET['errmsg']; 
Spageno-$ GET['pageno']; 
if(isset($ POST['senddel']))( 
$senddel-$ POST['senddel']; 
$dd-(array)$ POST['d']; 
) 
else $senddel-""; 
$ddp-$ SESSION['del']; 
require ("opendata.php.inc"); 
$numf- ($pageno-1) *$pagemax; 
$numl-$numf-*$pagemax; 
$sql-"SELECT * FROM card WHERE (serial»-'$numf' AND serial«-'$numl')"; 
$records-mysql query ($sql); 
if($sendde1==" 取 消 "){ 
Serrmsg=" 取 消 删除 ! "7 


header ("Location:manager.php?pageno-$pageno&&errmsg-$errmsg"); 
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} 


else if($sendde1 一 "确定 删除 ") ( // 确 定 删除 的 处 理 
while($row-mysql fetch array($records))( 
if(Sdd[S$row['serial']]--"del")(| 

$sql-"DELETE FROM usercard WHERE cardno-'$row[cardno]'"; 
mysql query ($sql); // 删 除 表 usercard 指定 卡号 的 记录 
$sql="DELETE FROM card WHERE serial-'$row[serial]'"; 
mysql_query ($sql) ; // 删 除 表 card 指定 序列 号 的 记录 
$errmsg.=$row['cardno'] ." 卡 成 功 删除 ! "o /7 反馈 哪些 卡 被 成 功 删 除 


) 
else if($dd[$row['serial']]!-"del" && $ddp[$row['serial']]e-'del')( 
$errmsg2.=$row['cardno']." 卡 取消 删除 ! — "; } // 反 馈 哪 些 卡 被 取消 删除 
} 
$errmsg.=$errmsg2; 
$sql="ALTER TABLE card DROP serial' 
mysql query($sq1); ”// 删 除 表 card 中 的 








$sql="ALTER TABLE card ADD serial int auto increment primary key FIRST "; 
mysql query ($sql); // 向 表 card 添加 字段 serial(int, auto increment, 
primary key FIRST) 
$sql-"ALTER TABLE usercard DROP serial"; 
mysql query ($sql); 
$sql="ALTER TABLE usercard ADD serial int auto_increment primary key 
FIRST "; 
mysql query ($sql); 
header ("Location:manager.php?pageno-$pageno&errmsg-$errmsg"); 
) 
$title=" 购 书 卡 管理 emdash; &mdash; 删除 "; 
include once("memhead.php"); 
red 
«div id="bt"> 购 书 卡 管理 smdash; smdash; 删 除 <hr /></div> 
«div id="err"> 以 下 购书 卡 确定 要 删除 吗 ? </div> 
<div id="bd"> 
<form action-"delcard.php?pageno-«?php echo $pageno;?»" method="post"> 
«table width-"100$" border-"1" cellspacing-"1" class-"tdl"» 
«tr id-"err" align="center"><td> 选 中 </td><td> 卡 号 </td><td> 余 额 </td> 
<td> 等 级 </td><td> 是 否 可 用 </td><td> 创 建 日 期 </td></tr> 
<?php 
while($rows-mysgl fetch array($records))( 
if(isset($ddp[$rows['serial']]))( // 提 取 并 显示 被 选中 的 记录 
echo "<tr align='center'><td><input type='checkbox' name= 
'd[".$rows['serial']."]' value-'del' checked»&nbsp; &nbsp; &nbsp; &nbsp; 
NO.".$rows['serial']." </td>"; 
echo "«td»".$rows['cardno']."«/td»«td»".$rows['balance']."jb«/td» 
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«td»".$rows['cardlevel']." </td> <td>" .$rows['cardstatus']."</td> «td» 
".$rows['ctime']." </td></tr>"; 


«tr align-"center"»«td colspan-"6"»«input type-"submit" name- 
"senddel" value=" 确 定 删除 ">><input type="submit" name-"senddel" value=" 取 
消 "> </tr> 
</table> 
</form> 
<div id="err" align="center"><?php echo $errmsg; ?></div> 
</div> 
<hr/> 
<iframe scrolling="no" width="780" height="70" src-"membottom.html" 
marginwidth="0" marginheight="0" border="0" frameborder="0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 





(12) 把 文档 以 delcard.php 为 文件 名 保存 在 member 文件 夹 中 。 


e aos 


本 段 代码 实现 对 购书 卡 的 删除 功能 。 前 面 的 ,BHP 程序 段 实 现 对 表单 输入 提交 后 的 处 理 一 删除 数据 
Ak card 和 usercard 中选 定 的 记录 并 整理 序列 号 ,后面 的 HTML 实现 待 删除 购书 卡 表单 和 反馈 信息 的 显示 。 
表单 处 理 程序 为 自 处 理 ， 确 认 删 除 或 取消 删除 都 重 定向 到 购书 卡 管理 页 面 manager php. 
第 8、11 fr: 自 定义 数组 变量 $dd、S$ddp 和 预定 义 全 局 数组 变量 $S_ SESSION["del'] 记 录 的 都 是 复 选 信 
息 ， 但 内 容 不 同 : $dd 记录 的 是 当前 页 表单 中 选中 的 一 定 要 删除 的 记录 行 ， 而 $ddp 和 
$_SESSION['del] 记 录 的 是 在 购书 卡 管理 页 面 中 选中 的 待 删除 的 记录 行 。 
第 12 一 16 行 : 读 取 数 据 表 card 中 的 当前 页 的 所 有 记录 以 备 选择 待 删除 记录 和 要 删除 记录 。 
第 21 一 43 行 : 单 击 “ 确 定 删除 ”的 处 理 ， 分 3 步 。 
第 22 一 33 行 : 分 别 从 数据 表 usercard 中 删除 选中 的 用 户 卡 (在 已 成 为 废 卡 时 ) 及 数据 表 card 中 
删除 选中 的 卡 ， 同 时 明确 指出 哪些 卡 被 删除 ， 哪 些 卡 被 取消 删除 。 
第 34 一 41 行 : 整理 数据 表 card 和 数据 表 usercard 的 序列 号 。 
第 34、38 行 : 设置 SQL 语句 ， 删 除 指定 表 中 的 字段 serial。 
F 36. 40 41: 设置 SQL 语句 , 添加 指定 表 中 的 字段 serial 具有 第 一 关键 字 和 自动 增加 (int) 
的 属性 . 
第 42 行 : 重 定向 到 购书 卡 管理 的 指定 页 面 ， 并 返回 操作 反馈 信息 。 
第 55—60 fp: 向 浏览 器 显示 在 managerphp 页 面 选中 的 待 删除 记录 行 ， 数 据 源 是 当前 页 的 记录 
Srecords。 其 中 
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第 564r: 寻找 当前 被 选中 的 行 . 
7 行 : 复 选 框 设置 了 被 选中 属性 ， 仍 以 数组 为 名 . 


(13) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(14) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
$errmsg=""; 
if(isset($ GET['errmsg'])) $errmsg=$ GET['errmsg']; 
Spageno-(int)$ GET['pageno']; 
if(isset($ POST['send']))( 
$sendcz-$ POST['send']; 
$dd-(array)$ POST["d"]; 
$money-(array)$ POST['money']; 
) 
else $sendcz-""; 
$ddp=$ SESSION['del']; 
require ("opendata.php.inc"); 
$numf- ($pageno-1) *$pagemax; 
$numl-$numf-*$pagemax; 
$sql-"SELECT * FROM card LIMIT $numf,$pagemax"; 
$records-mysql query ($sql); 
$i-0;  // 设 置 确定 后 重 定向 的 标识 
if ($sendcz==" 取 消 ") { 
$errmsg=" 取 消 充 值 ! "; 
header ("Location:manager.php?pageno=$pageno&&errmsg=$errmsg"); 
) 
else if ($sendcz==" 确 定 充值 ") { 





while($row-mysql fetch array($records)){ 
if (Sdd[S$row['serial']]--"del")( // 处 于 充值 选择 状 

if ($money[$row['serial']]--"")| // 断 定 没有 输入 金额 的 反馈 
$errmsg.=$row['cardno"] ." 卡 充值 数据 不 能 为 空 ! «br/»"; 
$i=$i+1; — // 只 要 有 没有 输入 金额 的 代 充 值 卡 存在 ， 就 要 定向 到 本 页 面 

) 

else( — // 计 算 充 值 后 的 金额 并 确定 购书 卡 等 级 ， 以 此 修改 两 字段 的 值 
$balance= (float) $money[$row['serial']]+(float) $row['balance']; 
if($balance»-2000) $cardlevel=" AF"; 

if($balance»-1500 && $balance«2000) $cardlevel="& E"; 
if($balance»-1000 && $balance«1500) S$cardlevel=" 银 卡 "; 
if($balance<1000) $cardlevel=" 普 通 卡 "; 

$sql="UPDATE card SET balance-'$balance',cardlevel-'$cardlevel' 

WHERE serial- ".$row['serial']; 












$recordsl-mysql query ($sql); 
$ddx[$row['serial']]=$row['cardno'] ." 卡 充值 成 功 ! <br/>"; // 设 置 
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elseif(Sdd[S$row['serial']]!-"del" && $ddp[$row['serial']]--"del") 
// 取 消 了 复 选 框 的 反馈 
$ddx[$row['serial']]=$row['cardno']." 卡 充值 取消 ! <br/>"; 
} 
$ SESSION['del']-$dd; // 修 改选 中 数组 的 内 容 
foreach($ddx as $key-»$value) // 提 取 反 馈 信息 


Serrmsg.-$value; 
if($i--0) header ("Location:manager.php?pageno-$pageno&errmsg-$errmsg"); 
else header ("Location:updatecard.php?pageno-$pageno&errmsg-$errmsg"); 
) 
$title=" 购 书 卡 管理 smdash; &mdash; 充值 "; 
include ("memhead.php"); 








?» 

«div id="bt"> 购 书 卡 管理 smdash; smdash; 充值 <hr /»«/div» 

«div id="err"> 以 下 购书 卡 确定 要 充值 吗 ? </div> 

<div id="bd"> 

«form name-"frm" action-"updatecard.php?pageno-«?php echo $pageno; ?>" 
method-"post"» 

«table width-"100$" border-"1" cellspacing-"1" class-"tdl"» 
«tr id-"err" align="center"> 
<td> 选 中 </td><td> 卡 号 </td><td> 余 额 </td><td> 等 级 </td><td> 充 值 金额 

«/td»«/tr» 
«?php 

while($rows-mysql fetch array(S$records))í 





if(isset(S$ddp[$rows['serial']]))( // 提 取 并 显示 被 选中 的 记录 

echo "<tr align='center'><td><input type='checkbox' name= 
'd[".$rows['serial']."]' value-'del' checked»&nbsp; &nbsp; &nbsp; &nbsp; 
NO.".$rows['serial']."«/td»"; 

echo "«td»".$rows['cardno']."«/td»«td»".$rows['balance']."j6«/td» 
«td»".$rows['cardlevel'] ." «/td»«td»«input type-'text' name= 


'money[".$rows['serial']."]' size-'30'/»«/td»«/tr»"; 


<tr><td align-"center"colspan-"5"»«input type="submit" name="send" 
value=" 人 确定 充值 ”onmousedown="pdsr () "> 
«input type="submit" name-"send" value=" 取 消 "></td></tr> 





</table> 
</form> 
<div id="err" align="center"><?php echo $errmsg;?></div> 
</div> 
<hr/> 
<iframe scrolling="no" width-"780" height="70" src-"membottom.html" 
marginwidth="0" marginheight="0" border="0" frameborder="0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 





BSE “会 员 注册 和 管理 设 计 5 数 所 区 了 
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(15) 把 文档 以 updatecard.php 为 文件 名 保存 在 member 文件 夹 中 。 


Gi. ans 


本 段 代码 实现 对 购书 卡 的 充值 功能 .与 删除 类 似 ， 不 同 之 处 在 于 除了 是 否 进行 充值 处 理 外 ， 还 要 对 输 
入 金额 的 有 效 性 进行 处 理 。 
第 17、27、46 一 47 行 : 自 定义 变量 $i 标识 充值 的 有 效 性 .0 表示 所 有 待 充值 的 购书 卡 处 理 完成 ， 可 
回 到 页 面 managerphp， 正 整数 表示 有 未 充值 的 购书 卡 待 处 理 ， 必 须 留 在 当 
前 页 updatecard.php. 
第 22 一 48 行 : 单 击 “确定 充值 ”按钮 的 处 理 ， 分 4 步 。 
第 23 一 42 行 : 对 待 充值 的 购书 卡 进行 处 理 。 
第 24 一 39 行 : 当前 页 面 中 选中 的 购书 卡 。 K 
第 25 一 28 行 : 未 输入 有 效 金额 :设置 反馈 信息 和 标识 。。 
5$ 29—38 行 : 输入 有 效 金额 : 计算 有 效 金 额 、 RRAK. 更 新 表 card 中 相应 字段 的 
信息 . 
$311: 反馈 信息 记录 在 才 组 sddplsrowgeabjjj， 把 处 理 过 与 未 处 理 的 卡 区 分 出 来 。 
第 40 一 41 行 : 设置 在 当前 页 面 取消 了 在 页 面 manager.php 中 选中 的 卡 的 反馈 。 
第 43 行 : 修改 被 选中 卡 的 状态 信息 -把 Sdd 赋予 $_SESSION['del]， 将 有 效 跟踪 在 页 
manager.php 选中 卡 的 充值 状态 。 
第 44 -~ AS 行 : 获取 本 轮 的 反馈 信息 。 
第 46- 47 行 : ERARD. 、 P» EN 
第 60—654r: 显示 当前 页 申 待 充值 的 购书 卡 信息 。 与 delcard.php 类 似 。 


l Kanra : 


5.4.9 ”调试 代码 


(1) 确认 memindex.php 等 相关 文件 已 在 服务 器 访问 目录 (如 cxhtdocs\wuya 或 
cAappserv www wuya)If]-- H3& member 下 。 

(2) 启动 浏览 器 ， 输 入 : http://localhost/wuya/member/memindex.php, fë Enter 键 后 ， 效 
RWE 5.13 所 示 。 





D) SE httpi//localhost/wuya/member/memindex php. D-cC|Benem 


iy E AAA 


注册 1 购书 卡 专区 | 修改 资 料 | 忘 记 窗 码 | 购书 卡 管理 1 返回 首页 





欢迎 进入 无 涯 书屋 的 会 员 管理 系统 
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513 ”会员 管理 主页 界面 





G) 单 击 “购书 卡 专区 ”链接 ， 效 果 如 图 5.14 所 示 。 





国 司 | 三 meyeareswwwmenberesnphpeanc1 0-8 


rp g TE EEE 真实 的 信息 


注册 | 购书 上 考区 | SAA EPEA) BREEN | FOET 
进入 购书 卡 专区 一 一 请 先 输入 会 员 号 及 密码 
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图 5.14 购书 卡 专区 身份 验证 页 面 000 
S us X $ 
O 当 单 去 SAR dell HULIDLIGA REL PEL oe ae 


Q) 如 果 输 入 的 会 员 号 不 正确 ， 则 在 按钮 下 方 的 提示 区 城 显示 “输入 的 会 员 号 不 正确 或 者 尚未 登录 为 会 
Rs 如 果 输入 的 密码 不 正确 ， 则 显示 AEAT. 这 是 在 服务 器 端 对 用 户 输入 的 合法 性 的 检查 。 


(4) 如 果 会 员 拥 有 购书 卡 ， 则 寿 图 5 14 的 表单 中 输入 正确 的 会 员 信 息 后 ， 单 击 “ 登 录 ” 
按钮 ， 效 果 如 图 5.15 所 示 。 PPRA EANNA HEN. 





[ CARTA 
«N 注册 | 购书 卡 专区 | grid isi trem i Ein) 
| 会 员 购 书 卡 查询 





alpang09. 目前 共有 3 张 内 蔬 卡 ， 共 2 而 。 本 页 是 第 1 页 列 出 了 第 1 到 2 条 记录 。 











piip 
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图 5.15 会 员 购书 卡 查询 
Lun 
QD 本 页 采用 了 分 页 显示 技术 ， 列 出 了 所 有 的 会 员 卡 信息 。 
Q 单 击 下 方 的 “申请 购书 卡 ” 按 钮 进入 图 5.16 所 示 的 “购书 卡 申请 ”页 面 。 


(5) 如 果 会 员 不 拥有 购书 卡 ， 则 在 图 5.14 的 表单 中 输入 正确 的 会 员 信息 后 ， 单 击 “ 登 
录 ” 按 钮 ， 效 果 如 图 5.16 所 示 。 


























第 5 章 ANERER 


© 2: TSS 





=) [E htphocalhostmuya/member/appiycard.php D-2|gmsrem 


& rrj £2 r3 员 * 更 z 
注册 GREEN | AAAH | 忘记 密码 | 购书 卡 管理 | 返回 首页 
购书 卡 申请 





alfang09-> 正 在 申请 购书 卡 


输入 购书 卡号 | ] 位 数 4-30， 必 须 由 字母 与 数字 组 网 ) 
输入 购书 卡 密码 | 人 位 数 6-20， 必须 由 字母 与 数字 组 成 ) 


确认 购书 卡 密码 








确定 | 路 过 
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图 5.16 n PRU 
培 说 明 A i 
如 果 单 击 “ 跳 过 ”按钮 ， 就 外 到 如 图 3 13 HRAARERIX. 


(6) 单 击 “ 修 改 资料 ”链接 界面 如 图 5.17 所 示 。 与 购书 卡 专 区 类 似 ， 只 是 标题 不 同 ， 
注意 观察 地 址 栏 上 的 URL 的 差异 。 SA 





i m NA 汪 p- 5| BuatAm—a. x] 
起 WuYabobkcom 、 
Derer A A CO 
注册 | 购书 卡 专区 | 做 区 资料 SPED 购书 卡 管理 | 返回 首页 
修改 个 人 资料 一 一 请 先 输入 会 员 号 及 密码 


lalfang 


ET 
































[95 | | 重新 输入 ] 
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517 ”修改 个 人 资料 一 一 输入 会 员 号 及 密码 


(D) 在 图 5.17 的 表单 中 输入 正确 的 信息 ， 单 击 “ 登 录 ” 按 钮 ， 进 入 如 图 5.18 所 示 的 
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(B htp/focalhost/wuya/member/modify.php D-9 Qsxemewsn 





PUTES Nh 
注册 | 购书 卡 专区 | 修改 资料 | 忘记 密码 | 购 共 卡 管理 | 返回 各 页 


修改 会 员 申 请 资料 





带 * 的 选项 是 必须 填写 的 
会 员 号 jallang 

tape 
Email[aiianf@citiz net 
会 员 密码 |111111 * ERAH, DAFIN 
Bis Ert s 
邮编 |201112 
地 址 | 上 海 市 荣 陀 区 师 大 一 村 xooeSxoo 空 
电话 号 码 |021>oooooooc ° 







































































LX 
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图 5.18。 修改 会 员 申 请 资料 _ 
un IT P m 
O 如 果 单 击 “ 重 新 填写 ”按钮 ,> 就 清除 文本 框 中 的 信息 < 
Q 如 果 修 改 了 相关 资料 后 单 去 “提交 ”按钮 ， 表 单 中 显示 会 员 的 所 有 资料 ， 隐 藏 下 方 的 两 个 按钮， 
同时 提示 区 中 显示 “修改 信息 : 荐 喜 你 ， 你 已 经 完成 了 个 人 资料 的 修改 1”. 


(8) 单 击 容 记 密 码 ”链接 ， 可 见 如 图 5.19 所 示 的 界面 ， 要 求 输入 会 员 ID。 











57) [B http://ocalhost/wuya/member/iogin.php?logn=3 D0 dusms mu. | 


v rr de A ACA. 


注册 | 购书 卡 专区 | 修改 资料 | 忘记 密码 | 购书 趟 管理 | 返回 首页 


密码 查询 一 一 请 先 输入 会 员 号 








往 入 会 员 3lalfang 
































重新 输入 
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图 5.19 查询 密码 一 -输入 会 员 号 
(9) 在 图 5.19 的 表单 中 输入 会 员 号 后 ， 单 击 “ 登 录 ” 按 钮 ， 可 见 如 图 5.20 所 示 的 界面 。 











[Brep/focahos ya/member /erget phe ERIIEY 


和 rE £A eA CR 





ANDREST | otis SPEA c3 s | ECET 
密码 查询 一 一 输入 住址 或 者 电子 邮件 账号 
Bani nar x 


[EU 
































人 中华 人民 共 和 国电 倍 与 信息 服务 业务 经 营 许可 证 > 编号; PICE 
MEUOMUSEEA ER: 1024x768 





5.20 ”密码 查询 一 一 输入 地 址 或 者 电子 邮箱 账号 
S un K 


O 如 果 单 击 “ 查 询 ”按钮 ， 会 在 提示 区 中 显示 “请 输入 地 址 或 者 电子 邮件 账号 1”; 

© 如 果 输 入 E-mail 或 者 住址 后 单 击 “ 查 询 ”按钮 ， 当 输入 未 正确 时 ， 会 在 提示 区 中 显示 “无 法 按 您 
的 输入 找到 您 的 密码 ,请 检查 输入 是 否 有 误 1! 请 重新 输入 "; 当 输 入 正确 时 ， 将 在 提示 区 中 显示 “X X X: 
您 的 密码 为 :X X X X X”"， 并 屏蔽 按钮 ， 如 图 5.2[ 所 示 。 


B Mp//ocalhos mys in D ~ c || nan 


TAr 
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图 5.21 ”密码 查询 成 功 的 界面 
(10) 单 击 “ 购 书 卡 管理 ”按钮 ， 可 见 如 图 5.22 所 示 的 界面 。 这 是 管理 员 登 录 界面 。 





B htpy/ocalhost/wuya/member/ioginphpogn=4 2-3 Bue sm. «| | 6 


PT £ AA CRCR 


注册 | 购 世 上 去 区 | HEEL] PENA] 购书 让 管理 | KOAT 


站 长 登录 一 一 请 输入 管理 员 账 号 及 密码 
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图 5.22 站 长 登录 一 一 输入 账号 和 密码 
































(11) 在 图 5.22 的 表单 中 输入 正确 信息 , 单 击 “ 登 录 ” 按 钮 , 可 见 如 图 5.23 所 示 的 界面 。 


)[ 和 hupyNocalhostwya/member/manager php PEE TP 


NF EZSTIT 
注册 | 购书 卡 专区 | Ait EEB | 购书 卡 管理 | 返回 首页 


购书 卡 管理 一 一 查询 








目前 共有 6 张 购书 卡 ， 共 3 页 。 本 页 是 第 1 页 列 出 了 第 1 到 2 条 记录 。 输入 页 次 : 


T $8 Wu EEEN 
62855966 2200 元 钻石 卡 Y 2018 年 02 月 15 日 
62856966 500 元 Bit Y 2018 年 02 月 15 日 
ze | an] sa 


第 需 | 开 一 页 | 最 后 一 页 
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图 5.23 bai 
“添加 ” 可 见 如 图 5.24 所 示 的 界面 。 





i 





(12) 在 图 5.23 中 ， 单 击 


e (B hep/localhost wya/men mbajda php" P-cellg 


nL 


X £ sri estet iov ses Pe c 
z WBEM 
Y 








J x T IRANS [62857966 T 
N AMPH ee [rrrTTT 


En MES 55 R2 























确定 添加 | | 返回 
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5.24 ”购书 卡 管理 一 一 添加 


Lun 

O 给 入 购书 卡 信息 后 ， 单 击 “确定 ”按钮 ， 会 在 提示 区 中 显示 “添加 成 功 1”.。 

© 单 击 “ 返 回 ”按钮 ,会 返回 如 图 5.23 所 示 的 当前 界面 ， 同 时 可 见 界面 状态 栏 中 购书 卡 信息 的 变化 。 
可 以 通过 单 击 下 方 的 翻 页 导航 链接 查看 添加 的 购书 卡 信息 




















(13) 在 图 5.23 中 ， 选 中 某 个 复 选 框 后 ， 单 击 “ 删 除 ”按钮 ， 可 见 如 图 5.25 所 示 的 界面 





[B rapyhlocalhosuwwa/memberdalcard php?pageno=3 P ~ Ó | B eem ine 


& rra £e r3 Á Lj 3 


注册 1 购书 卡 专区 | 修改 资料 | 忘记 密码 | 购书 卡 管理 | KOET 


购书 卡 管理 一 一 删除 





以 下 购书 卡 确定 要 者 R93? 
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525 购书 卡 管理 一 删除 


CAT 
(D 在 图 5.23 中 , 如 果 没 有 选择 就 单 击 araman 则 在 提示 区 中 显示 “必须 选中 一 个 购书 卡 !”， 
也 可 以 选择 多 个 复 选 框 。 
© 在 图 5.25 P, AR “确定 删除 ”按钮 ， 则 回 到 图 523 中 的 当前 界面 
并 在 提示 区 中 显示 “X X X X X X X X 卡 取消 删除 1”。 
G 在 图 5.25 v, wR OS DRE JUR 单 击 An^ dm, 则 回 到 图 5.23 中 的 当前 界面 并 
在 提示 区 中 显示 “X XX XX 义 XX 十 成功 删除 1”。 4 
图 在 图 5.25 v, Xx “取消 ”按钮 ， 则 回 到 图 523 中 的 当前 界面 并 在 提示 区 中 显示 “取消 删除 1”。 


(14) 在 图 5:23 中 ， 选 中 某 个 复 选 柜 后 ， 单 击 “ 充 值 ”按钮 ， 可 见 如 图 5.26 所 示 的 
界面 。 N 











[E iiesocalhost/weya/memberjupdatecard phpypageno=3 D ~ © || B Fert IER HB 


ILS YI 
注册 | 购书 卡 专区 | fv ELES) 购书 卡 管理 | 返回 首页 
购书 卡 管理 一 一 充值 





以 下 购书 卡 确定 要 充值 吗 ? 


选中 
NOS 
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图 5.26 ”购书 卡 管理 一 一 充值 





PHP 动 态 网 页 设计 与 制作 案例 教程 第 = 版 ) 了 ) 


Lau 明 

(D 在 图 5.23 中 ， 如 果 没 有 选择 就 单 击 “ 确 定 充值 ”按钮 ， 会 在 提示 区 中 显示 “必须 选中 一 个 购书 卡 !”， 也 
可 以 选择 多 个 复 选 框 。 

®© 在 图 5.26 中 ， 如 果 取消 选择 的 某 个 复 选 框 ， 单 击 “ 确 定 充值 ”按钮 ， 则 在 提示 区 中 显示 “取消 X 
XXXXXxXX 卡 的 充值 !”。 

© 在 图 5.26 中 ， 如 果 包 含 了 选择 的 复 选 框 ， 单 击 “确定 充值 ”按钮 ， 则 回 到 图 5.23 中 的 当前 界面 并 
在 提示 区 中 显示 “XXXXXXXX 卡 充值 数据 不 能 为 空 !"。 

图 在 图 5.26 中 ， 在 文本 框 中 填 入 了 合法 数据 ， 单 击 “ 确 定 充值 ”按钮 ， 则 回 到 图 5.23 中 的 当前 界面 
并 在 提示 区 中 显示 “XX X X XXX X 卡 充值 成 功 !”。 

© 在 图 5.26 中 ， 单 击 “ 取 消 ” 按 钮 ， 则 回 到 图 S23 中 的 当前 界面 并 在 提示 区 中 显示 “取消 充值 !”。 


(多 wns 


5.5 ”表单 数据 处 理 


5.5.1 PHP 与 表单 
l. HTML 表单 
HTML K 本 文件 中 创建 ,在 浏览 器 中 显示 。 其 格式 为 





<form name="frmname" method="POST" action="procees.php" enctype="application/ 
x-www-form-urlencoded" > 
<input type="text" name="user name"> 


<input type="submit" name-"cmdLogin" value=" 登 录 " onClick-"return 
checkvalid();"» 
«/form» 


un 

®© method 属性 告诉 浏览 器 如 何 发 送 表 单 ， 通 常 取 值 为 GET( 默 认 ) 和 POST. 

@ action 属性 告诉 浏览 器 把 数据 发 送 到 哪里 ， 即 服务 器 上 处 理 表单 数据 的 URL. 

图 enctype 表明 表单 的 MIME 编码， 通常 是 application/x-www-form-urlencoded( 默 认 )、ultipart/form-data 和 
text/plain, 

















在 <form></form> 之 间 可 包含 车 干 个 表单 域 ， 如 <input>、<textarea>、<select> 等 ， 常 / 


输入 类 型 的 表单 域 如 表 5.13 所 示 。 
表 5.13 常用 输入 类 型 的 表单 域 


输入 类 型 | 主要 属性 do xk 
name 创建 一 个 单行 文本 框 
size size 指定 了 文本 框 的 大 小 
maxlength maxlength 指定 允许 输入 的 最 多 字符 数 
value value 指定 文本 框 的 初始 值 





text 
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( 续 ) 
输入 类 型 | 主要 属性 dà — xk 
name 创建 一 个 多 行文 本 区 域 
textarea cols cols 指定 了 文本 区 域 的 行 数 
rows rows 指定 每 行 允许 输入 的 最 多 字符 数 
— Bi text 创建 一 个 密码 文本 框 ， 文 本 框 内 以 星 号 代替 输入 的 内 容 
ili T 类 似 于 单行 文本 框 
name 创建 一 个 复 选 框 (可 以 同时 选中 多 个 ) 
checkbox checked checked 指定 是 否 被 选中 
value value 指定 复 选 框 的 初始 值 
radio 类 似 checkbox | 创建 一 个 单 选 框 (只 能 选中 一 个 ) 
name 创建 一 个 菜单 (只 能 选中 一 个 ) 或 列表 框 (可 以 同时 选中 多 个 ) 
jst option option 指定 菜单 或 列表 框 的 选项 
idt size size 指定 了 列表 框 可 见 选项 的 个 数 
multiple multiple 指定 列表 框 是 硅 能 多 选 
pidd name 创建 隐藏 域 
au value value 指定 隐藏 域 的 初始 值 
name 创建 提交 按钮 ， 把 表单 提交 给 由 action 指定 的 程序 处 理 
nm value value 指定 按钮 上 的 标签 
reset IH] submit 创建 重 置 按钮 一 清除 全 部 输入 把 表单 重 置 为 原始 状态 
button 同 submit 创建 按钮 
name 创建 图 像 域 
image src src 指定 图 像 域 的 URL 
align align 指定 图 像 域 的 对 齐 方式 
file name 指定 要 上 传 到 服务 器 的 文件 。enctype 为 multipart/form-data 





为 了 更 好 地 实现 对 表单 的 浏览 定位 ， 常 用 CSS 与 表格 元 素 相 结合 的 方式 来 布局 。 
2. PHP 的 表单 处 理 机 制 


当 用 户 填写 表单 后 , 浏览 器 对 表单 数据 进行 URL 编码 , 并 且 把 数据 提交 到 服务 器 作 进 
一 步 处 理 ， 如 图 5.27 所 示 。 


TE - =] 
HTTP 请 求 .@ 接受 表单 数据 | Fen» 


= 
浏览 器 接收、 翻译 并 显示 Intemet ”处 理 数 据 , 响应 REA 




















5.27 PHP 的 表单 处 理 机 制 示意 


un 


O 当 浏览 器 向 服务 器 发 送 Web 页 面 请 求 时 ， 它 建立 一 个 TCP/IP 连接 。 请 求 以 HTTP 格式 处 理 ， 其 


中 的 第 1 行 如 : 
- 
-= 


GET / procees.php HTTP/1.1  // 指 定 处 理 输入 数据 的 方法 是 GET， 要 检索 的 文件 是 
procees.php, HTTP 的 版 本 是 1.1 





动态 网 页 设计 与 制作 案例 加 第 = 后 ( 7) 
一 D 
= e 


© 在 服务 器 得 到 这 个 文件 后 ， 就 把 它 发 送 到 PHP 进行 处 理 。 作 为 服务 器 一 部 分 的 PHP， 能 够 访问 浏 
览 器 传送 到 服务 器 的 表单 数据 . 首先 自动 把 表单 元 素 的 名 称 转 化 为 PHP 变量 ; 使 用 5_REQUEST 数组 变量 
保存 GET 4e POST 数据 ; 对 数据 进行 处 理 后 ， 把 输出 结果 替换 到 HTML 文档 。 在 PHP 处 理 完 数据 后 ， 服 
务 器 发 送 一 个 响应 头 标 ， 并 把 处 理 后 的 信息 送 给 浏览 器 。 例 如 : 

HTTP/1.1 200 OK 

Content-type:text/html 

© 当 浏览 器 接受 这 个 页 面 时 ， 它 会 翻译 其 中 的 HTML 代码 ， 并 在 浏览 器 中 显示 页 面 。 
5.5.2 ”表单 数据 的 采集 

1. GET 方 式 


如 果 表 单 处 理 不 会 明显 地 改变 页 面 状态 ， 就 采用 GET 方式 。 它 主要 用 于 静态 HTML 
文档 、 图 像 或 对 数据 库 查询 结果 的 简单 检索 。 

如 果 在 <form> 标 记 里 没有 明确 设置 要 使 用 的 方法 ， vore GET J; X. 

GET 方式 以 “查询 字符 串 ” 的 形式 把 数据 附加 到 -URL 的 后 面 。 当 用 户 单 击 “ 提 交 ” 
按钮 后 , 浏览 器 对 数据 进行 编码 , 把 它 以 “关键 字 - 值 ”对 的 形式 附加 到 当前 URL 的 后 面 (以 
问号 为 前 导 ， 之 后 不 能 含有 空格 )。 格 式 如 下 : 0 


http://www. docalhost/waya/register/iogin?idoi 


S un 


GET 方式 的 缺点 : 

(D 数据 不 安全 。 因 为 表单 通过 URL 发 送 ， 所 以 对 于 用 户 是 可 见 的 。 

@ 数据 规模 上 有 所 限制 因为 服务 器 对 URL 长 度 的 限制 》 如 UNIX 的 限制 是 1024 字 节 。 

© ERTE. 因为 输入 的 数据 可 能 被 缓存 ， 所 以 浏览 器 可 能 会 从 缓存 中 获取 前 一 个 请 求 的 结果 而 
不 是 当前 的 请 求 a p 站 


2. POST 方式 

当 使 用 POST 方式 获取 数据 时 ， 浏 览 器 不 把 编码 数据 放 在 查询 字符 串 里 ， 而 是 对 数据 
打包 放 在 http 头 标 里 。 与 GET 方式 不 同 ,这 时 的 消息 体 没 有 规模 限制 而且 在 浏览 器 的 地 
址 栏 里 是 不 可 见 的 ， 因 此 通常 使 用 于 发 送 大 量 数据 的 场合 ， 或 者 像 数据 库 发 送 数据 、 发 送 
电子 邮件 或 者 修改 数据 的 场合 。 
要 使 用 POST 方式 ， 必 须 在 HTML 文档 的 <form> 标 记 里 设置 method 属性 ， 变 量 被 保 
存 的 方式 及 用 于 PHP 脚本 的 方式 都 与 GET 方式 相同 。 
在 大 多 数 情况 下 ， 采 用 POST 方式 传输 表单 的 数据 ， 一 方面 是 出 于 安全 的 考虑 ， 另 一 
方面 可 以 封装 更 为 复杂 的 二 进 制 数据 和 更 多 的 信息 , 而 GET 方式 只 能 传输 文本 信息 ， 且 大 
小 有 限 ( 不 大 于 2KB)。 

3. 其 他 提交 方式 

通过 JavaScript 也 可 以 把 表单 数据 提交 ， 但 本 质 上 仍 离 不 开 POST 方式 和 GET 方式 。 例 如 : 

<input type-"password" name-"psw" onkeypress-"if(event.keyCode--13) form. 
sumbit();" /» 
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当 按 Enter 键 后 即 代 表 提 交 表单 。 对 于 登录 表单 ， 因 为 输入 的 密码 要 提交 ， 所 以 在 密 
码 框 处 设置 按 Enter 键 完成 。 脚 本 form.sumbit0 用 来 完成 表单 的 提交 操作 ， 与 单 击 “ 提 交 ” 


按钮 的 作用 是 完全 一 样 的 。 
"e 





























如 何 防止 表单 被 自动 提交 ? 
产生 自动 提交 的 原因 有 多 个 ， 一 是 用 户 编制 一 些 软件 自动 完成 登录 、 注 册 等 过 程 ; 二 是 为 了 大 
量 注册 账号 或 者 试图 破解 别人 的 密码 等 的 “机 器 人 ”， 都 会 对 系统 带 来 危害 。 解决 的 方法 是 用 位 图 验 
证 码 将 “机 器 人 ” 拦 在 系统 外 。 
在 表单 中 加 入 一 个 文本 框 与 一 张 图 片 ， 例 如 


<input type="text" name="textcode" size="4" /> 
<img src="image/code.jpg?act=getCodeImg" id="cd" alignt="absmiddle" /> 


该 图 片 是 随机 生成 的 含 数字 的 位 图 , “机 器 人 ”很 难 识别 位 图 中 如 什么 字 笠 。 
在 处 理 表单 时 ， 同 样 也 要 先进 行 验证 码 的 检验 ， 只 有 包含 验证 码 的 数据 才 可 以 被 处 理 ， 从 而 拦 
截 了 所 有 程序 自动 添加 的 数据 ， 详 见 8.3 节 内 容 。 \ 


如 何 防止 表单 被 多 次 提交 ? 

由 于 网 络 的 延迟 ， 可 能 导 臻 用户 多 次 提交 辣 东 的 表单 数据 ， 这 样 很 容易 造成 数据 的 重复 处 理 。 
例如 ，PHP 要 将 提交 的 数据 插入 数据 表 中 ,由 于 重复 提交 ， 导 致 数据 表 中 生成 了 多 条 完全 一 样 的 记 
录 。 可 以 通过 “专用 钥匙 ” 来 解决 这 个 问题 。 

在 显示 表单 时 ， 就 为 该 表单 分 配 一 个 数据 囊 ( 角 是) 在 提交 家 间 时 ， 只 有 正确 的 钥匙 才 被 视 为 有 
效 数据 ， 一 旦 认定 是 有 效 数据 3 该 数据 就 被 作废 。 

首先 在 页 面 中 生成 这 个 钥匙 ， 和 例如 

saie E ^ Y vc NV 


session stai t(); Es 
&key-rand (0, 1000) ; // 随 机 生成 数据 串 
$ SESSION["KEY"]-Skey; 。 // 保 存 数 据 串 信息 ， 以 便 在 提交 时 检查 
7> 
同时 在 表单 中 生成 一 个 隐藏 域 : 
<input type="hidden" name-"key" value-"?php echo $key;?»" /> 
然后 ， 当 表单 提交 时 ， 检 查 数据 的 钥匙 
if(!checkKey($ REQUEST["key"])) exit(); 
function checkKey ($key) { 
session start(); 
if($key--$ SESSION["key"] && $ SESSION["key"] !-"")( 
$ SESSION["key"]-""; // 及 时 销毁 钥匙 
return true; 
H 
else return false; 
) 


一 旦 判断 出 当前 数据 是 有 效 的 ， 就 立即 销毁 “钥匙 ”。 
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5.5.8 ”表单 数据 处 理 描述 


一 个 全 面 的 表单 处 理 流程 如 下 : 客户 端 初步 校 验 一 提交 表单 一 数据 采集 一 服务 器 数据 
校 验 一 数据 处 理 一 对 数据 反馈 。 

1. 客户 端 初步 校 验 

在 客户 端的 数据 校 验 主要 核查 数据 是 否 合法 、 合 理 ， 如 输入 数字 的 地 方 是 否 输入 了 文 
字 、 密 码 长 度 是 否 有 效 、 电 子 邮 箱 是 否 符 合 电子 邮箱 规范 ， 这 样 能 保证 有 效 的 数据 传输 到 
服务 器 ， 避 免 让 用 户 等 待 几 十 秒 的 时 间 最 后 弹出 一 个 错误 提示 。 

客户 端的 数据 校 验 一 般 采 用 JavaScript 脚本 ， 在 提交 前 或 用 户 输入 时 就 进行 判断 ， 减 
轻 了 服务 器 端的 负载 。 

2. 提交 表单 

当 提 交 表 单 时 ， 表 单 的 action 属性 指明 表单 提交 后 处 理 表单 的 URL， 默 认 这 个 属性 ， 
处 理 表单 的 URL 就 默认 为 表单 所 在 的 页 面 。 处 理 表单 的 PHP 程序 首先 实现 条 件 检查 ， 判 
断 表单 是 否 已 经 被 提交 了 。 

表单 的 method 属性 设置 数据 的 提交 方式 ， 有 :POST 和 GET 两 种 。 

要 检查 使 用 的 是 哪 一 种 请 求 方式 ， 可 以 通过 如 下 语句 : 

if($ SERVER[ 'REQUEST METHOD']--'GET')( PHP 语句 } 


if($ SERVER['REQUEST METHOD']--'POST')( PHP 语句 ) 

3. 数据 采集 

(1) 使 用 超 全 局 数据 数组 获得 表单 数据 。PHP 预定 义 的 超 全 局 变量 数组 $_ GET 和 
$_POST 能 获取 由 GET 和 -POST 方式 提交 的 表单 数据 。 数 组 的 关键 字 对 应 表单 的 name 属 
性 ， 数 组 的 值 对 应 用 户 输 入 的 内 容 。 

(2) (EHS REQUEST 数组 收集 表单 的 数据 。 由 于 $_REQUEST 数组 囊括 了 各 类 表单 信 
息 , 不 必 了 解 传递 使 用 的 方式 及 数据 的 来 源 。 还 可 获取 来 白 URL、 链 接 和 cookie 等 的 数据 ， 
因此 未 必 安 全 。 












































PHP 预定 义 的 超 全 局 变量 数组 
除了 超 全 局 数据 数组 $ GET fe$ POST 外 ，PHP 还 预定 义 如 表 5.14 所 示 的 其 他 数组 .。 
表 5.14 PHP 预定 义 的 超 全 局 变量 数组 


数组 名 (不 推荐 ) 别 名 描 述 
包含 指向 脚本 全 局 范围 当前 全 部 可 用 变量 的 应 用 。 其 关 
键 字 是 全 局 变量 的 名 称 
SHTTP COOKIE VARS | $ COOKIE | 通过 cookie 向 脚本 提供 的 值 
SHTTP GET VARS S GET 全 局 关联 数组 ， 包 含 通过 GET 方式 传递 到 脚本 的 变量 
SHTTP_POST_VARS S_POST 全 局 关联 数组 ， 包 含 通过 POST 方式 传递 到 脚本 的 变量 





SGLOBALS 














数组 名 (不 推荐 ) 别 名 di 述 





SHTTP FILES VARS $ FILES 通过 POST 文件 上 传 提供 的 变量 

SHTTP SERVER VARS | $_ SERVER | Web 服务 器 设置 的 变量 

SHTTP_ENV_VARS $ ENV 通过 环境 提供 给 脚本 的 变量 
$ REQUEST | 通过 GET、POST 和 cookie 提供 给 脚本 的 变量 (不 可 靠 ) 
$ SESSION | 当前 注册 到 脚本 会 话 的 变量 
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PHP 创建 变量 保存 信息 的 方式 有 3 种。 

QD) 短 样式 ， 即 PHP 直接 创建 与 输入 表单 域 的 name 属性 同名 的 变量 ， 变 量 的 值 就 是 在 这 个 表单 域 输 
入 的 信息 。 例 如 ， 单 行文 本 框 的 name="uname"，PHP 创建 变量 Sunaine' 其 值 为 在 文本 框 中 输入 的 内 容 . 

Q) 中 样式 , 即 PHP 预定 义 的 超 全 局 变量 数组 $S GET 和 $_P9ST:- 例 如 , 单行 文本 框 的 name="uname"， 
则 预定 义 变量 $S_GET[uname]、S_POST['uname']， 其 值 为 给 入 的 内 容 。 

© 长 样式 ， 即 PHP 5.0 以 前 版 本 使 用 的 超 全 局 变量 数组 SHTTP_GET_VARS、SHTTP_POST_VARS. 
这 些 变量 已 经 很 少 使 用 了 . 

创建 变量 保存 信息 的 方式 取决 于 PHP. 的 版 本 ， 如 果 是 PHP 4.2.0 以 前 的 版 本 ，php.ini 文件 里 的 
register_globals 被 设置 为 on， 允 许 使 用 短 祥 式 。 使 用 短 样 式 的 问题 在 于 这 样 的 简单 变量 可 能 指 来 自 URL. 
cookie 或 session、 环 境 、 文 件 上 传 等 途径 的 输入 内 容 ， 并 不 一 定 是 来 自 表 单 的 。 数 据 来 源 不 明 会 产生 安全 
风险 .为 此 ，PHP 设计 者 禁止 使 用 短 样式 ， 把 php.ini 文件 里 的 register_globals 设置 为 off， 使 用 推荐 的 中 
样式 能 够 更 准确 地 说 明 远 据 以 特定 方式 传递 到 服务 器 ; 3:00 PHP 5.0 时 ， 可 以 在 php.ini 文件 里 把 
register long_arrays 设 置 为 o 信 来 禁止 使 用 长 样式 > 

虽然 长 样式 与 中 笠 式 代表 同样 的 数据 ,但 它们 是 不 同 的 变量 ， 若 在 程序 里 同时 使 用 一 个 长 样式 名 称 和 
其 别名 ， 改 变 一 个 变量 并 不 会 影响 另 一 个 . 

(3) 获取 多 选项 表单 的 数据 。HTML 的 select 和 checkbox 标记 创建 的 表单 域 都 允许 用 
户 选择 多 个 选项 ，PHP 使 用 数组 来 接收 和 处 理 相关 数据 。 首 先 表 单 域 的 名 称 属性 就 是 一 个 
数组 ， 例 如 





<input type-"select" name-"chat" src-"../image/chat.jpg" /> 














在 提交 表单 时 ， 如 果 使 用 短 样式 ，PHP 创建 数组 ， 其 中 每 个 元 素 被 赋予 选中 的 值 ， 如 
果 使 用 中 样式 ， 利 用 关联 数组 来 检索 输入 的 数据 及 表单 域 的 名 称 。 

(4) 获取 使 用 图 像 按钮 表单 的 数据 。image 表单 域 一 般 起 着 提交 按钮 的 作用 。 当 单 击 图 
片 时 ， 除 了 表单 被 发 送 到 的 服务 器 外 ， 同 时 还 发 送 了 鼠标 在 图 像 上 单 击 的 位 置 chatx 和 


chaty, PHP 自动 转化 为 chat_ x 和 chat y。 相 关 代 码 如 下 。 



























































«input type-"image" name-"chat" src-"../image/chat.jpg" /> 
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4. 服务 器 数据 校 验 


不 论 是 POST 还 是 GET 提交 的 数据 ， 绝 大 部 分 都 是 文本 形式 的 ， 即 PHP 中 没有 文 
本 、 整 数 、 浮 点 数 等 的 差别 , 用 $_ REQUEST 获取 的 都 是 字符 串 形式 , 所 以 可 能 会 在 PHP 
的 各 类 运算 中 发 生 严重 的 错误 。 另外， 客户 端的 脚本 功能 有 限 ，PHP 却 可 以 获得 几乎 所 
有 可 能 的 数据 并 判断 其 是 否 有 效 ， 如 果 用 户 改变 浏览 器 的 安全 策略 阻止 脚本 的 运行 ， 则 
客户 端的 脚本 就 不 会 被 执行 。 因 此 ， 可 以 认为 PHP 校 验 关 平 全 局 ， 客 户 端的 校 验 能 提 
升 品质 。 

5. 数据 处 理 


计算 和 存储 是 通常 意义 上 的 “数据 处 理 ” 针对 不 同 的 应 用 和 不 同 的 要 求 ， 需 要 各 种 各 
样 的 计算 方法 ， 而 计算 的 结果 需要 保存 ， 或 者 写 入 普通 文件 ， 或 者 保存 在 数据 库 中 。 

PHP 对 表单 数据 的 处 理 主要 是 对 数据 的 计算 、 存 储 和 反馈 。， 

(1) 表单 域名 称 中 的 字符 处 理 。 由 于 PHP 接收 表单 数据 时 ”表单 域名 称 与 PHP 变量 名 
相对 应 ， 在 表单 域内 输入 的 内 容 与 PHP 变量 值 相对 应 ,但 表 单 域名 称 和 用 户 输入 的 内 容 未 
必 符合 PHP 变量 的 规范 ， 因 此 PHP 必须 对 此 进行 处 理 

有 效 的 PHP 变量 名 以 字母 或 下 划 线 开 始 ， 后 面 跟着 任意 数量 的 字母 、 数 字 或 下 划 线 ， 
当 PHP 接收 表单 数据 时 ， 表 单 域名 称 就 变 成 短 样式 的 变量 名 或 中 长 样式 的 关键 字 。 一 般 来 
说 , PHP 在 把 它们 传递 到 脚本 时 不 会 改变 这 些 名 称 。 但 当 表单 域名 称 中 包含 句点 或 空格 时 ， 
PHP 会 用 下 划 线 代替 它们 ， 从 而 形成 有 效 的 PHP 变量 名 。- 因 此 ， 强 调 在 建立 HTML 表单 
时 ， 为 表单 域 命名 要 记 住 尽 量 符合 PHP 变量 的 规范 。 > 

Q) 表单 域内 输入 的 内 容 中 包含 斜 线 符 。 若 在 ,phpiini 文件 里 把 magic quotes gpc i 
置 为 on( 默 认 )， 则 大 多 数 从 外 部 资源 返回 数据 的 函数 会 用 斜 线 对 引号 转 义 。 如 果 在 表单 
域内 输入 了 引号 ,PHP 会 用 反 斜 线 对 这 些 于 号 转 义 ， 输 入 了 反 斜 线 ，PHP 会 再 添加 一 个 
反 斜 线 转 义 它 。 PHP 的 stripslashes( ) 函 数 可 以 清除 这 些 添加 的 反 斜 线 , 返回 填写 表单 的 原 
始 数据 。 

函数 stripslashes( ) 的 格式 
string stripslashes(string str) 


6. 对 数据 反馈 


向 用 户 反 馈 数 据 处 理 的 结果 主要 有 : 错误 提示 信息 ， 如 “系统 发 生 错误 ”“ 找 不 到 数据 
库 ”“ 数 据 保存 失败 ”“ 文 件 找 不 到 ”等 ; 成 功 提示 信息 ， 如 “数据 被 保存 ”表单 提交 成 功 ” 
等 。 表 述 反 馈 信 息 一 般 遵 循 以 下 规则 。 

(1) 明确 告知 程序 是 否 正常 。 

(2) 错误 的 可 能 原因 。 

(3) 建议 用 户 做 什么 。 

(4) 语言 简洁 ， 避 免 专业 术语 。 

(5) 人 性 化 处 理 。 
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表单 处 理 页 面 的 刷新 问题 


表单 提交 后 ， 在 单 击 浏览 器 的 “刷新 ”按钮 后 ， 会 出 现 如 图 528 所 示 的 对 话 框 ， 如 果 单 击 “ 重 
试 ” 按 钮 ， 就 会 又 一 次 提交 登录 请 求 ， 如 果 单 击 “ 取 消 " 按 钮 ， 就 可 能 出 现 “ 网 页 已 过 期 ”的 信息 。 


Microsoft Internet Explorer 


A REL RR AURERE, Ces "Ri ERESEAT. 


图 5.28 刷新 页 面 提示 框 


显然 ， 这 时 不 需要 再 登录 ， 而 是 让 页 面 重新 显示 一 次 ， 这 就 是 ,表单 不 理 页 面 的 刷新 间 题 *。 它 
会 导致 重复 提交 表单 信息 ， 引 起 数据 重复 保存 、 误 覆盖 等 严重 问题 * 要 防止 “刷新 ”的 表单 处 理 ， 
只 需 在 处 理 结束 后 页 面 重 定向 。 例 如 


| 
header("location:login.php?id-1"); 


这 样 ， 在 新 页 面 中 ， 不 管用 户 怎么 刷新 都 不 会 出 现 上 玉 提 示 。 


如 何 收集 放 在 不 同 页 面 、 不 同 表单 上 的 数据 ? 


用 户 要 输入 的 信息 很 多 时 就 有 必要 将 表单 分 别 放 在 不 同 的 页 面 中 ， 一 步 一 步 地 填写 ， 全 部 放 
在 一 个 页 面 中 让 用 户 一 口气 填写 下 来 会 使 用 户 感到 压力 和 恶 惧 . 

常规 的 方法 是 二 页 一 个 表单 ， 提 交 一 页 处 理 一 次 ， 反 馈 时 将 页 面 重 定向 到 下 一 页 表单 ， 但 必须 
设置 一 个 状态 标识 ， 用 以 表示 当前 处 理 到 第 让 页 或 处 理 到 哪 种 状态 了 ， 因 为 只 有 全 部 页 面 处 理 完 时 
才 代表 这 个 庞大 的 表单 被 处 理 完 。 

另 一 种 方法 是 把 多 次 提交 的 数据 暂时 存 起 来 ， 在 最 后 一 页 提交 时 再 处 理 。 问 题 是 如 果 填 写 的 数 
据 出 了 问题 还 需要 返回 那个 表单 所 在 的 页 面 ， 这 种 方法 在 程序 编写 上 简单 但 在 用 户 使 用 时 不 推荐 。 

以 上 两 种 方法 都 涉及 一 个 数据 临时 存放 的 问题 由 于 PHP 内 核 机 制 与 JSP/ASPNET 有 较 大 的 不 
同 ， 页 面 间 的 数据 传递 只 能 通过 以 下 3 种 方法 。 

(1) session: 把 数据 放 在 SESSION， 等 待 下 一 个 页 面 取出 。 

(2) cookie: 把 数据 放 在 COOKIE， 等 待 下 一 个 页 面 取出 。 

G) 表单 隐藏 域 : 把 数据 放 在 下 一 页 面 表单 中 的 隐藏 域 里 ， 在 下 一 页 面 继续 被 提交 。 

采用 前 两 种 方法 ， 在 程序 处 理 上 较为 方便 ， 但 SESSION 和 COOKIE 在 容量 上 都 是 有 限 的 。 





5.6 cookie 与 会 话 管理 


5.6.1 数据 传递 概述 


动态 网 页 的 显著 特点 是 能 根据 给 定 的 参数 来 决定 显示 的 内 容 。 参 数 来 自 网 页 本 身 ， 也 
可 能 来 自 别 的 网 页 ， 还 可 能 是 用 户 设 定 的 。 所 以 ， 如 何 传递 参数 是 一 个 无 法 回避 的 问题 。 
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传递 参数 实际 上 是 让 变量 在 多 个 地 方 都 能 使 用 到 它 的 值 。 例 如 ， 从 一 个 页 面 跳 转 到 另 
一 个 页 面 时 ， 需 要 把 前 一 个 页 面 的 变量 值 传递 到 后 一 个 页 面 。 表 单 是 实现 数据 传递 的 一 种 
方式 。 使 用 预定 义 全 局 变量 SGOLBALS 也 是 一 种 方式 。 

最 常见 的 数据 传递 方式 是 URL 地 址 传递 参数 ， 例 如 

http://locahost/login.php?id-1 

“? ”后 是 要 传递 给 这 个 页 面 的 参数 ,“=” 后 的 是 参数 值 ， 在 PHP 中 可 以 使 用 数组 
$ REQUEST 或 $ GET 来 获取 参数 的 值 。 
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http://locahost/search.php?title=%B9%D8%D3%DAPHP 是 什么 意思 ? 
这 些 符 号 实际 上 也 是 普通 的 字符 串 ， 只 是 被 编码 (Encode) 过 了 . “7 " "&" 和 “=” 是 特殊 字符 ， 


如 果 参 数 中 也 有 这 些 字符 就 必须 把 它们 转化 为 其 他 字符 ， 有 些 浏览 器 的 ,URL 中 禁用 中 文 ， 这 样 中 文 
也 必须 被 编码 。 编 码 后 的 值 需要 用 urldecode SACK EUR. 


客户 端的 cookie 和 服务 器 端的 会 话 (session) 是 两 种 重要 的 数据 传递 与 保存 的 技术 ， 它 
们 各 有 长 短 ， 在 Web 系统 中 发 挥 着 重要 的 作用 。 


5.6.2 cookie NL 





l. cookie 的 存 取 E 

cookie 是 客户 端 (浏览 器 ) 支 持 的 存储 区 ， 页 面 可 以 把 一 些 信息 保留 在 访问 者 的 计算 机 
上 。 当 一 个 页 面 访问 请 求 发 出 时 ， 会 查找 是 否 有 有 效 的 cookie 可 用 ， 若 找到 就 将 cookie 中 
的 信息 一 起 传递 到 服务 器 ， 这 样 PHP 程序 就 可 以 分 析 和 获取 cookie 中 的 数据 。 

$ COOKIE. 可 以 在 所 有 的 程序 中 直接 使 用 ， 在 函数 和 方法 中 不 需要 使 用 global 
$ COOKIE 将 其 声明 为 全 局 变量 。 


AN $ COOKIE 4& PHP 4.1.0 及 以 后 的 版 本 中 使 用 ， 对 于 以 前 的 版 本 使 用 SHTTP_COOKIE_VARS. 


出 于 安全 和 性 能 方面 的 考虑 ， 客 户 端 不 会 给 cookie 很 大 的 存储 空间 (不 大 于 4KB)， 这 
是 因为 它 要 随 HTTP 包 每 次 都 被 提交 给 服务 器 。cookie 可 以 被 客户 端的 其 他 程序 访问 和 修 
改 ， 用 户 也 可 以 禁用 cookie 功能 。 所 以 ，cookie 并 不 可 靠 ,其 优点 是 能 长 期 保存 在 客户 端 ， 
可 以 与 客户 端的 脚本 共享 其 中 的 数据 ， 适 合 于 存放 一 些 不 太 重要 的 个 性 化 信息 ， 如 访问 次 
数 、 最 近 一 次 搜索 的 关键 字 等 。 

2. cookie 的 属性 

cookie 的 属性 主要 包括 以 下 几 种 。 

(1) 名 称 。 每 个 都 有 自己 的 名 称 ， 相 同 的 名 称 被 认为 是 同一 个 。 

(2) 值 。 即 核心 数据 ， 要 求 其 长 度 尽量 小 。 

(3) 有 效 期 。 过 期 的 cookie 将 被 删除 。 

(4) 有 效 域 。cookie 是 属于 某 个 网 站 (域名 ) 的 ， 一 般 情况 下 不 允许 访问 其 他 网 站 的 cookie. 


er 
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3. cookie 的 管理 


在 PHP t}, cookie 通过 setcookie( ) 函 数 创建 赋值 并 通过 $_COOKIE 变量 获取 。 





bool setcookie (string name[,string value[,int expire[,string path[,string 
domain[,int secure]]]]]) 

name:cookie 的 名 称 。 

value:cookie 的 值 。 

expire:cookie 的 过 期 时 间 。 

path: 指 明 domain 域 下 的 哪个 日 录 中 的 页 面 允 许 访问 这 个 cookie, 

domain: 指 明 这 个 cookie 可 以 在 哪个 域名 下 被 访问 。 

secure:cookie 是 否 仅 在 安全 HTTP 上 使 用 。 


S um 


(D cookie 是 客户 端 传 来 的 值 。 在 设置 了 cookie 的 页 面 中 ， 首 次 访问 $_COOKIE 是 取 不 到 值 的 ， 当 第 
二 次 访问 到 这 段 代 码 时 ，$_COOKIE 变量 才能 取 到 它 的 值 . X 

Q 由 于 Cookies 是 HTTP 信息 头 中 的 一 部 分 因此 SetCookie 函数 必须 在 向 浏览 器 发 送 任何 输出 之 
前 调用 。 对 于 header( ) 函数 也 有 同样 的 限制 。 

© 不 要 把 过 多 的 内 容 放 在 cookie 中 而 不 删除 ， 这 样 会 起 过 客户 端的 限制 而 失去 数据 ， 太 多 的 cookie 
意味 着 有 太 多 的 数据 要 在 网 络 上 传输 ， 这 在 一 定 程度 上 也 会 影响 效率 。 


5.6.3 ”会 话 管理 


会 话 ， 简单 地 说 就 是 在 浏览 器 和 服务 器 之 间 的 一 次 对 请 过 程 ， 这 个 过 程 从 第 一 次 服务 
器 收 到 浏览 器 的 页 面 请 求 开始 到 最 后 一 次 请 求 为 IEs 事实 上 ， 服 务 器 并 没有 办 法 确认 哪 次 
请 求 是 最 后 一 次 请 求 ， 可 以 通过 php.ini 设置 请 求 延 时 ; 如 一 般 设 置 请 求 24min 内 再 没有 发 
来 请 求 则 认为 这 次 会 话 结束 。 

l. session 的 存 取 


session 是 针对 一 个 会 话 期 间 而 存在 的 数据 ， 即 一 个 会 话 对 应 一 个 session， 并 且 在 整个 
会 话 期 间 任何 被 访问 到 的 PHP 页 面 都 可 以 获取 session 中 保存 的 数据 。 每 个 访问 者 都 有 自 
己 的 一 个 session， 所 以 像 用 户 信息 等 全 局 性 的 数据 非常 适合 放 在 session 中 。 

$ SESSION 可 以 在 程序 任何 地 方 用 如 下 代码 来 存 取 数据 。 


$ SESSION['key']-" ffi"; // 把 " 值 "保存 在 关键 字 为 key 的 session 变量 中 
$valuse-$ SESSION['key']; // 把 关键 字 为 key 的 session 变量 中 的 值 赋予 变量 value 








LN 注 S SESSION 在 PHP 4.1.0 及 以 后 的 版 本 中 使 用 ,对 于 以 前 的 版 本 使 用 SHTTP_SESSION_VARS。 


与 cookie 不 同 的 是 ，session 的 数据 保存 在 服务 器 端 ， 不 需要 每 次 都 要 从 客户 端 传 来 ， 
也 不 会 自动 传递 给 浏览 器 端 。 根 据 客户 端 发 来 的 页 面 请 求 中 的 SESSIONID 来 查询 是 否 有 对 
应 的 session 可 用 ， 若 有 则 为 PHP 提供 ， 若 没有 则 创建 一 个 供 PHP 使 用 ， 直 到 这 次 会 话 结 
JR. session 才 会 被 清除 。 

2. session 的 属性 


session 的 属性 包括 以 下 几 种 。 






































(1) 生存 期 。 生 存 期 即 会 话 期 间 。 
D 容量 。 由 于 服务 器 是 多 用 户 的 结构 ， 因 此 它 为 每 个 session 分 配 的 空间 是 有 限 的 ， 
通常 不 大 于 4KB。 超 出 容量 的 session 会 导致 数据 的 丢失 或 程序 的 异常 。 


3. session 管理 


(E PHP 中 ， 访 问 session 中 的 数据 首先 通过 session_start() 函 数 来 激活 session 功能 ， 再 
通过 变量 $_ SESSION[mame'] 对 session 中 的 数据 进行 存 取 ,最 后 通过 函数 session_unset (或 
session destroy () 销 毁 session. 











bool session start (void) // 激 活 session 功能 

bool session register(mixed name [, mixed ..]) // 注 册 session 变量 

void session unset (void) // 有 释放 所 有 session 变量 

bool session destroy (void) // 销 毁 所 有 session 变量 
SÍ un 


session 功能 默认 是 不 启用 的 ， 所 以 在 使 用 session 前 必须 使 用 Jssion_start 启 用 该 功能 ， 而 且 这 个 函 
数 必须 是 在 没有 任何 页 面 输出 的 时 候 执行 ,否则 将 出 错 .通过 修改 php.ini 中 的 项 session.auto_start( 设 置 为 
1)， 可 实现 让 自动 启用 session 功能 而 不 必 每 次 使 用 Session start(). 


CPP is 


通过 学 习 本 章 案 例 ， 对 PHP AAAA OASTEA RAAN iR, 主要 包 
括 以 下 几 点 。 : 

(1) PHP 对 表单 的 处 理 方式 一 POST; 和 GET。 

(2) PHP 页 而 闻 的 数据 传递 技术 一 cookie 和 session。 

(3) 使 用 预定 义 的 一 组 超 全 局 变量 数组 实现 数据 传递 功能 。 


d $4152 


(1) 简 述 PHP 对 表单 的 处 理 过 程 和 方式 。 
(2) PHP 怎样 实现 对 页 面 间 的 数据 传递 ? 
(3) 比较 cookie 技术 和 session 技术 的 异同 。 


Y suas 


"i8 5-1 AJ GUA cookie) 
项 目 目标 ， 

(1) 演示 cookie 的 一 个 应 用 。 

D 展示 如 何 创建 一 个 简单 的 登录 页 面 。 
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WR. 
(1) 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 p5-1.php 的 文件 ， 上 和 载 到 服务 
器 上 的 exercisevchs 文件 夹 中 。 


(2) 将 下 面 的 HTML 文本 ， 并 将 这 个 文件 上 载 到 服务 
器 上 ， 放 在 与 文件 p5-1 


(3) 在 Web 浏览 器 上 , 访问 与 p5-1.html 相关 联 的 URL, 观察 执行 结果 (屏幕 截 
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(4) 在 文本 框 中 输入 文本 ， 单 击 “ 提 交 ” 按 钮 ， 观 察 执行 结果 (屏幕 截图 表示 )。 
(5) 分 析 程序 p5-1.php 的 代码 : 

@ 如 何 存储 认证 用 户 的 输入 ? 

@ cookie 在 页 面 中 的 作用 及 这 样 做 有 什么 益处 ? 


项 目 5-2 联系 人 表单 
项 目 目标 : 
(1) 演示 函数 的 定义 和 创建 。 
(2) 演示 程序 余 段 (stub) 技 术 。 
步骤 : 
(1) 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 p5 e 文件 ， 上 载 到 服务 器 
上 的 exercisevchs 文件 夹 中 。 , Y 
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(2) 将 下 面 的 HTML 文本 存放 在 一 个 名 为 p5-2.ine 的 文件 中 ， 并 将 这 个 文件 上 载 到 服 
务 器 上 ， 放 在 与 文件 p5-2.php 相同 的 文件 夹 中 。 


(3) 将 下 面 的 HTML 文本 放 在 一 个 名 的 文件 中 , 并 将 这 个 文件 上 载 到 服务 
器 上 ， 放 在 与 文件 p5-2.php 相同 的 文 tiep À 
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QD PHP 的 函数 的 定义 。 
@ 体会 include 的 作用 。 

图 在 update_database0 函 数 中 的 函数 体内 只 有 一 个 echo 语句 ， 这 样 的 函数 称 为 余 
段 (stub) 函 数 。 在 程序 开发 过 程 中 ， 使 用 这 种 函数 ， 可 以 在 完全 编写 之 前 运行 和 测试 它 。 


项 目 5-3 验证 用 户 输 入 
项 目 目标 ， 
(1) 演示 条 件 语句 的 使 用 。 
(2) 展示 一 种 验证 表单 数据 的 方法 。 
步骤 : 
(1) 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 p5-3.php 的 文件 ， 上 载 到 服务 
器 上 的 exercise\ch5 文件 夹 中 。 


SEE 
Gy 
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(2) 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 p5-3.html 文件 ， 上 载 到 服务 器 
上 的 exercisevchs 文件 夹 中 。 
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G) 在 Web 浏览 器 上 ,访问 与 p5-3.html og e 观察 执行 结果 (屏幕 截 图 表示 )。 

(O) KEKERASAN MEARI: 

(5) 分 析 程序 55:3Php 的 代码 : — 0 00- 
© PHP 的 证 语句 在 HTML 中 的 作用 。 
O 着 在 昵称 、 姓 名 、 邮 箱 地 址 处 ， 不 输入 文本 ， 就 单 击 “ 提 交 ” 按钮 会 出 现 什么 

情况 ? 









网 上 社区 设计 与 PHP 数据 库 访 问 


通过 本 章 的 学 习 ， 能 够 使 读者 : 

(1) 理解 PHP 访问 数据 库 的 机 制 。 

(2) 掌握 PHP 查询 数据 的 方法 。 

(3) 掌握 留言 板 和 聊天 室 的 设计 方法 。 


FIRR 


本 章 为 读者 准备 了 以 下 学 习 资源 : 

(1) 示范 案例 : 展示 “网 上 社区 ? 即 聊 天 室 和 留言 板 的 设计 与 实现 过 程 ,对 应 本 章 的 6.1~6.5 
节 。 案 例 代码 存 放 在 文件 来“ 教学 资源 \wuya\ch6\chat” 和 “教学 资源 \wuya\ch6\bbs” 中 。 

(2) 技术 要 点 : 描述 “PHP 访问 MySQL 数据 库 ” 的 技术 要 点 ， 对 应 本 章 的 6.6 节 。 其 
中 的 示例 给 出 了 相关 技术 的 说 明 实例 ， 代 码 存放 在 文件 夹 “教学 资源 \extendvch6\”。 

(3) 实践 项 目 : 代码 存放 在 文件 夹 “ 教 学 资源 \ exercise\ch6\” 中 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 : 

(1) 解读 示范 案例 的 分 析 和 设计 。 

(2) 模仿 练习 : 选择 一 个 PHP 集成 开发 工具 , 如 Dreamweaver, 按照 实现 步骤 重 现 案例 。 

(3) 扩展 练习 : 按 实践 项 目的 要 求 ， 先 明确 项 目 目标 ， 再 在 PHP 集成 开发 环境 中 实现 
项 目 代 码 ， 接 着 对 代码 中 的 PHP 语言 要 素 进 行 分 析 ， 提 升 理 解 和 应 用 能 力 。 

学 习 过 程 中 ,提倡 结对 或 3 人 组 成 学 习 小 组 , 一 起 探讨 和 研究 会 员 注 册 和 管理 的 设计 ， 
但 对 PHP 访问 MySQL 数据 库 的 学 习 和 具体 项 目的 实现 还 是 鼓励 能 独立 完成 。 
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本 章 案例 介绍 如 何 设计 和 实现 网 上 社区 模块 ， 对 应 主页 中 的 留言 板 和 聊天 室 链 接 ， 其 
中 涉及 PHP 访问 MySQL 数据 库 的 相关 知识 。 


S 预备 知识 
6.1 网 上 社区 概述 


聊天 室 是 网 友 间 在 线 交流 互动 的 主要 渠道 之 一 。 在 聊天 室 中 , 网 友之 间 即 便 互 不 相识 ， 
但 仍 可 以 就 自己 喜好 的 主题 畅所欲言 。 对 商务 网 站 ， 常 常 利 用 聊天 宝来 吸引 用 户 加 入 ， 这 
也 成 为 主导 网 站 成 功 的 关键 因素 之 一 ， 因 而 成 为 网 站 的 标志 之 一 。 

留言 板 是 网 友 间 离线 交流 互动 的 主要 渠道 之 一 。: 在 留言 板 中 ， 网 友 可 以 看 到 之 前 使 用 
者 的 留言 ， 也 可 以 留 下 自己 的 言论 。 对 商务 网 站 用 留言 板 可 以 了 解 用 户 的 需求 和 意见 。 
留言 板 的 功能 可 大 可 小 ,小 则 简单 地 让 用 户 浏览 留言 和 写 一 个 短篇 留言 , 具有 回复 的 功能 ， 
大 则 可 以 做 到 能 按 不 同 主题 分 门 别 类 的 Web BBS 系统 ， 再 大 就 是 Web 社区 系统 了 。 

本 书 案例 中 的 网 上 书店 ， 设 置 了 聊天 室 和 留言 板 来 加 强 与 顾客 的 交互 ， 构 筑 了 一 个 较 
为 完善 的 交流 社区 。 

为 了 方便 用 户 ， 在 主页 中 设 辕 了 醒目 的 链接 。 i Nt 或 EN ”的 链接 
后 ， 在 独立 的 窗口 中 打开 相应 的 子 系统 。 

在 本 书 案例 中 的 留言 板 中 ， 往往 根据 用 户 身份 于 设 轩 功能 ， 如 普通 用 户 可 以 疫 轩 留言 
的 主题 、 查看 所 说 王 题 的 留言 信息 ， 管 更 订 人 多 能 得 看 所 有 主题 的 留言 信息 ， 还 可 以 对 此 
进行 删除 和 屏蔽 管理 > 

在 本 书 案例 中 的 聊天 室 中 ， 首先 要 确认 歼 天 者 的 身份 进入 聊天 室 后 ， 普 通用 户 可 以 
看 到 当前 在 线 的 用 户 。 聊 天 的 过 程 是 编辑 所 要 表达 的 信息 并 发 送 到 指定 的 显示 区 域 ， 供 在 
线 的 网 友 浏 览 。 编 辑 发 言 信息 是 最 主要 的 一 个 环节 ， 可 以 使 用 文字 输入 的 方式 ， 也 可 以 选 
择 一 些 固定 的 动作 描述 或 图 片 表达 ， 发 言 时 带 一些 表 情 会 更 加 生动 有 趣 。 案 例 采 用 了 两 种 
发 言 模式 : 一 种 是 表情 加 文字 输入 ， 另 一 种 是 选择 动作 描述 。 此 外 ， 还 可 以 通过 设置 文字 
的 颜色 来 表达 发 言 时 的 心情 。 































































































先例 向 入 


"y 


6.2 留言 板 的 设计 
6.2.1 留言 板 的 架构 


本 案例 留言 板 具 有 如 下 功能 。 


(1) 浏览 留言 。 显 示 留 言 ， 具 有 分 页 浏览 功能 
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(2) 回复 留言 。 通 过 页 面 中 的 “回复 留言 ” 超 链 接 ， 进 入 写 留言 页 面 。 














G) 屏蔽 留言 。 管 理 员 身份 的 用 户 才 具 有 屏蔽 不 适宜 公布 留言 的 功能 ， 通 过 页 面 中 的 








“屏蔽 留言 ” 超 链接 实现 。 





(4) 删除 留言 。 对 于 相同 主题 或 长 期 无 回复 的 留言 ， 可 通过 页 面 中 的 “删除 ” 超 链接 





























实现 对 留言 的 删除 。 
留言 板 的 工作 流程 如 图 6.1 所 示 。 
浏览 留言 
FE a a [D] 
z 请 求 浏览 A 


dd 
浏览 留言 | 请 
回复 留言 [x 

隐藏 /删除 留言 | 浏 读数 据 

Wi 


写 数据 





图 6.1 /留言 板 的 工作 流程 
un 


(1) 用 户 向 服务 器 发 出 访问 请 求 并 输入 用 户 身份 信息 。 

(2) 服务 器 根据 用 户 的 身份 显示 主页 面 的 功能 : 

Q@ 一 般 用 户 ， 在 留言 板 的 主页 中 有 留言 和 浏览 功能 ”在 浏览 时 还 可 以 回复 留言 。 

@ 管理 员 ， 在 留言 板 的 主页 中 有 管理 功能 ， 可 浏览 个 回复 、 删 除 和 屏蔽 留言 。 

G) 写 好 的 留言 信息 记录 在 数据 库 中 。 查 看 留言 时 ， 从 数据 库 中 读 取 并 显示 在 页 面 上 。 


6.2.2 ”留言 板 的 设计 描述 
1. 逻辑 结构 设计 
根据 对 留言 板 架构 的 描述 ， 可 得 其 迪 辑 结构 ， 如 图 6.2 所 示 。 


主页 bbsindex.php i 
除 留言 主题 delete.ph 
链接 菜单 d 题 delete.php 
浏览 主题 留言 


浏览 留言 主题 管理 员 登 录 bbsviewinfo_m.php 
bbsview.php loginadmin.php NRY 





























In| £ 81 F rewrite.php 浏览 留言 
按钮 表单 bbsviewinfo.php 





图 6.2 留言 板 的 逻辑 结构 





W 
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2. 数据 库 设计 





在 MySQL 数据 库 服务 器 上 建立 guest 数据 库 ， 其 中 包含 数据 表 guestlist 和 replylist, 
两 个 表 的 结构 基本 一 样 ， 各 字段 的 定义 和 说 明 如 表 6.1 所 示 。 


表 6.1 guest 数据 库 中 的 数据 表 guestlist 和 replylist 结构 


























字 R 类 型 说 Hg & ” 注 
serial int(5) 留言 序列 表 auto_increment 主键 
name varchar(20) 使 用 者 姓名 
btitle varchar(255) 数据 表 guestlist 中 的 字段 
bserial int(5) 数据 表 replylist 中 的 字段 
email varchar (30) 使 用 者 邮箱 地 址 CURRENT_TIMESTAMP 
msg text 留言 内 容 
btime timestamp 留言 时 间 
flag varchar (1) 显示 标志 Y/N RUAY 








LAN 注 通过 phpMyadmin 创建 上 述 数 据 库 表 . 在 MySQL 的 data 文件 夹 中 会 自动 创建 以 此 数据 库 为 名 


的 文件 夹 。 
3. 界面 设计 


(1) 留言 板 主页 bbsindex.php 的 页 面 布局 如 下 所 示 。 其 中 的 样式 定义 在 bbs.css 中 。 


Logo: 180x50 
空白 : 780x10 


^E]: 780x5 


(2) SM 





Banner: 00*50 





L; 780x50 


欢迎 词 
网 页 版 权 信息 


write.php 的 页 面 布局 如 下 所 示 。 





Logo: 180x50 


Banner: 600x50 





空白 :; 780x10 





链接 菜单 : 780x50 


























空白 : 780x5 
标题 栏 

昵称 单行 文本 表单 E-mail 单行 文本 表单 
主题 单行 文本 表单 
内 容 多 行文 本 表单 

提交 按钮 表单 

处 理 后 反馈 信息 

网 页 版 权 信息 





FANE SAN GL rewrite.php 的 页 面 布局 同 写 留言 页 write.php. 
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E 题 页 bbsview.php 的 页 面 布局 如 下 所 示 。 





(3) 浏览 留言 





Logo: 180x50 Banner: 600x50 





空白 : 780x10 





链接 菜单 : 780x50 




















空白 :780x5 
标题 栏 
留言 主题 信息 栏 
ET? | m 发 帖 时 间 | 同 复 次 数 
主题 1( 超 链接 ) | 昵称 | xxxx 年 XX 月 Xx 日 XX 时 Xx 分 Xx 秒 | xx 











网 页 版 权 信息 





LN 注 管理 员 浏览 留言 主题 页 adminview.php 的 页 面 布局 类 同 浏览 留言 主题 页 bbsview.php, 不 同 之 处 
在 于 多 了 一 个 删除 链接 列 (处 理 程序 : delete.php). 


(4) 浏览 主题 留言 页 bbsviewinfo.php 的 页 面 布局 如 下 所 示 。 
Logo: 180x50 Banner: 600x50 


空白 :780x10 





空白 : 780x5 











标题 栏 
EB. XX 发 帖 时 间 : X XXX—XX—XX XX:XX:XX 
WR XX 
邮件 : ada@sas 回复 留言 ( 超 链接 ) 
回复 留言 序号 ，X FS XXX 
回复 者 : Xxx 邮件 ，ada@sas 回复 留言 ( 超 链接 ) 
分 页 显示 信息 栏 
网 页 版 权 信 息 





ÁN 管理 员 浏 览 留 言 主题 页 adminviewinfo.php 的 页 面 布局 类 同 浏览 留言 主题 页 bbsviewinfo.php， 
不 同 之 处 在 于 多 了 一 个 屏蔽 链接 (处 理 程序 :hide.php). 


6.3 留言 板 的 实现 





由 留言 板 的 设计 可 见 ， 留 言 板 中 各 页 面 的 头 部 和 底部 信息 相同 ,为 了 使 代码 得 到 重用 ， 
把 它们 分 别 放 在 一 个 文档 中 ， 通 过 CSS 对 网 页 表现 加 以 实现 。 网 页 中 的 图 像 需 要 通过 图 形 


处 理 软件 或 动画 软件 实现 。 











局 
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V 准备 工作 


(1). 确认 在 站 点 根 目录 已 建立 文件 夹 bbs 作为 存放 与 留言 板 相关 的 文件 。 

(2) 确认 在 bbs 文件 夹 中 建立 文件 夹 css 和 文件 夹 images。 

(3) 在 动画 软件 Ulead GIF Animator 中 制作 留言 板 的 banner， 以 文件 名 bbs.gif 保存 在 
文件 夹 images 中 。 


FANE bbs.gif 的 制作 方法 与 主页 的 banner 类 似 


(4) 把 图 像 文 件 logo.gif 也 复制 一 份 放 在 文件 夹 images 中 。 


y 
M CSS 编 码 
代码 文件 : bbs.css 


(1) 启动 Dreamweaver， 新 建 CSS 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ; “输入 如 下 代码 


Gcharset "utf-8"; 

/* CSS Document */ 

tapp {  /* 定 义 骆 个 页 面 的 样式 */ 
width: 780px; 
margin: 0 auto; 

} 

#top {  /* 定 义 项 部 样式 */ 
height: 50px; 
width: 780px; 

J 

#bt {  /* 定 义 标题 样式 */ 
font-size: 24px; 
font-weight: bold; 
color: $399; 
height:40px; 
background-color: #FFC; 
vertical-align: middle; 
text-align: center; 
margin-top: 10px; 
padding-top: 10px; 

} 

.nemulink{ 
font-size: 14px; 
color: #099; 
width: 780px; 
margin-top: 10px; 
background-color: #FFEFCE; 
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Wod { ”/* 定 义 表单 样式 */ 
font-size: 14px; 
color: #F30; 

} 

#bitem (  /* 定 义 链接 样式 */ 
font-size: l6px; 
color: $099; 
font-weight: bold; 

) 

.tdl {  /* 定 义 表单 样式 */ 
font-size: 14px; 
color: #F60; 
background-color: #FFC; 

) 

terr { PENR 
height: 20px; 





MERR 


font-size: 14px; 
color: #099; 
background-color: #FFEFCE; 
padding-top: 10px; 

} 

#copyright (  /* 定 义 底部 版 权 信 
height: 60px; 





text-align: center; 
font-size: 14px; 
line-height: 1505; 

) 

table ( 
margin: Opx; 
padding: 0px; 
width: 780px; 

} 

form { 
margin: Opx; 
padding: 0px; 
width: 780px; 


ink { color: 4399; ) 
sited ( color: #906; ) 
:hover ( color: $F90; ) 








:active ( color: $099; ) 


width: 780px; 
line-height: 150$; 





(3) 把 文档 以 bbs.css 为 文件 名 保存 在 文件 夹 bbs/css 下 。 
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V PHP 编 码 


6.3.1 网 页 的 头 部 、 尾 部 和 系统 配置 文件 
代码 文件 : bbshead.php, bbsbottom.html 和 sys conf.inc 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 留 言 板 </title> 
<link href-"css/bbs.css" rel="stylesheet" type="text/css" /> <!-- 链 接 样 
式 文件 css/bbs.css--> 
</head> 
<body> 
<div id="app"> <!-- 最 外 层 区 域 --> 
«div id="top"> <!-- 包 含 网 站 LOGO 和 网 页 banner 的 区 域 --> 
«img src-"images/logo.gif" width-"180" /><img src-"images/bbs.gif" 
width-"600"/» 
«/div» 
<div align="center" class-"nemulink"» <!-- 包 含 导 航 栏 的 区 域 --> 
<a href="write.php"> 我 要 留言 </a>&nbsp; | &nbsp; «a 
href="bbsview.php"> 查 看 留言 </a>&nbsp; | &nbsp; 
<a href="loginadmin .php"> 版 主管 理 </a>&nbsp; | &nbsp; «a href-"../index.php"» 
返回 首页 </a> 
</div> 


(3) 把 文档 以 bbshead.php 为 文件 名 保存 在 文件 夹 bbs 下 。 


v M" 


这 只 是 网 页 的 一 部 分 ， 由 于 每 个 网 页 中 的 头 部 和 尾部 都 是 相同 的 ， 从 代码 重用 的 角度 ， 把 它们 存放 在 
一 个 独立 的 文件 中 ， 用 系统 函数 require_once() 包 含 并 运行 在 网 页 中 ， 能 提高 代码 效用 。 

第 10 行 : 定义 了 一 个 区 域 ， 采 用 类 样式 app。 注 意 此 行 <div> 的 闭 标记 未 包含 在 此 文件 中 。 
第 11 一 13 行 : 定义 了 一 个 区 域 ， 采 用 类 样式 tpp， 装 载 Logo 和 Banner 图 片 。 


第 14 一 17 行 : 定义 了 一 个 区 域 ， 采 用 类 样式 nemulink， 表 现 链接 菜单 。 








(4) 在 Dreamweaver 中 ， 打 开 站 点 根 文件 夹 中 的 bottom.html。 

(5) 把 文件 以 bssbottom.html 为 文件 名 另存 在 文件 夹 bbs F, 并 修改 Link 标记 中 的 href。 
(6) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

(7) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
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<!--sys_conf.inc: 系 统 配置 文件 --> 
«?php 
// 配 置 数据 库 全 局 变量 
$DBHOST-"localhost"; 
SDBUSER-"root"; 
SDBPWD-""; 
SDBNAME-"guest"; 





(8) 把 文档 以 sys. confine 为 文件 名 保存 在 文件 夹 bbs F- 


(3^ 代码 解读 


把 数据 库 的 配置 参数 作为 全 局 变量 存放 在 一 个 单独 的 文件 中 有 利于 维护 * 例如 , 要 修改 服务 器 的 密码 ， 
只 需要 在 这 里 修改 就 可 以 了 。 使 用 系统 函数 include_once( ) 包 含 到 PHP 中， 就 可 以 使 用 这 些 变 量 了 。 


6.3.2 ”留言 板 的 主页 一 欢迎 页 
代码 文件 ，bbsindex.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 * 视 图， 输入 如 下 代码 。 
<?php require once("bbshead.php") ?> <!-- 使 用 系统 函数 require_once( ) 包含 
bbshead.php--> 

«div id-"bt" align="center"> 欢 迎 光临 留言 板 </div> <!-- 设 置 欢迎 文本 区 域 ， 应 用 
bt 样式 --> 

<hr/> 

<!-- 使 用 <iframe> 标 记 加 载 bbsbottom.html--» 

<iframe scrolling-"no" width-"780" height-"70" src-"bbsbottom.html" 
marginwidth-"0" marginheight-"0" border-"0" frameborder-"0" align-"center" > 
不 支持 </iframe> 

</div> <!-- 与 bbshead 中 的 <div id="app"> 对 应 --> 
</body> 

</html> 


(3) 把 文档 以 bssindex.php 为 文件 名 保存 在 文件 夹 bbs 下 。 





6.3.3” 写 留言 页 和 回复 留言 
代码 文件 ，write.php、rewrite.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
$err="";$action=""; $name=""; $email=""; $msg-"";$btitle-""; 
if(isset($ GET['err'])) $err=$ GET['err']; 
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if(isset($ POST['action']))( 
$action-$ POST['action']; 
$name-$ POST['name']; 
$email-$ POST['email']; 
$msg-$ POST['msg']; 
$btitle-$ POST['btitle']; 
r 
if ($action==" 放 弃 ") 
echo "<meta http-equiv-'Refresh' content='0;url=bbsindex.php'>"; 
else if($action==" 提 交 "){ 
if(S$name!-"" && S$email!-"" && $msg!-"" && $btitle!-"")( 
include once("sys conf.inc"); 
// 使 用 mysqli 建立 与 MySQL 数据 库 的 连接 
$connection-mysqli connect ($DBHOST, $DBUSER, $DBPWD, $DBNAME) or 
die (" 无 法 连接 数据 库 ! ") ; 
mysqli query($connection,"set names 'utf8'");  // 设 置 字符 集 
// 向 服务 器 发 送 查 询 请 求 
$query-"INSERT INTO guestlist (name,btime,msg,email,btitle 
values('$name',CURRENT TIMESTAMP, '$msg','Semail','S$btitle')"; 
$result=mysqli_query ($connection, $query) or die (" 存 入 数据 库 失 败 ") ; 
mysqli close($connection) or die(" 无 法 断 开 与 数据 库 的 连接 ") ; 
$err=" 填 写 留 言 成 功 ! &nbsp; &nbsp; &nbsp; &nbsp; 3 秒 后 自动 返回 .\n"; 
echo "<meta http-equiv-'Refresh' content-'3;url-bbsindex.php'»"; 
) 
else( 
$err=" 出 错 了 !&nbsp; &nbsp; &nbsp; enbsp; 信 息 不 全 ! 昵 称 、 邮 箱 、 主 题 和 内 容 是 
必须 填写 的 !"; 
echo "<meta http-equiv-'Refresh' content='2;url=".$ SERVER 
['PHP SELF']."?err-Serr'»"; 
) 





) 

require ("bbshead.php"); 

?» 

«div id="bt"> 写 留言 «hr /»«/div» 

«div id-"bd"» 
«form method="post" action-"«?php echo $ SERVER['PHP SELF'];?»"» 
«table width-"100$" border-"0" cellspacing-"0" class-"tdl"» 

<tr><td align-"right"»&nbsp;Wü&nbsp;TK:&nbsp«/td» 





<td><input name="name" type="text" size-"45" maxlength-"20"»«/td» 
<td align-"right"»Email:&nbsp«/td» 
<td><input name="email" type="text" size="48" maxlength="20"></td> 
</tr> 
<tr><td align="right">&nbsp; X&nbsp;fi:&nbsp«/td» 
<td colspan="3"><input name="btitle" type="text" size="113" 
maxlength= "80"/> </td></tr> 
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<tr><td align="right">gnbsp; 内 &nbsp; 容 :&nbsp</td> 
<td colspan="3"><textarea name="msg" cols="85" rows="8"></textarea> 
«/td»«/tr» 
<tr><td align="center" colspan-"4"»«input type="submit" name-"action" 
value=" 提 交 "> 
<input type-"reset" value- 
value=" 放 弃 "> 
</td></tr> 
</table> 
</form> 
</div> 
«div id-"err" align="center"><?php echo $err; ?></div> <!-- 提 示 信 息 显 示 
区 域 --> 
<hr/> 
<iframe scrolling="no" width="780" height="70" src="bbsbottom.html" 
marginwidth="0" marginheight="0" border="0" frameborder="0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 








"><input type-"submit" name-"action" 





(3) 把 文档 以 write.php 为 文件 名 保存 在 文件 夹 bbs F- 


(D 程序 中 用 到 的 变量 详解 如 表 6.2 所 示 


X62 程序 中 用 到 的 变量 




















5 om 


m om 名 
$ SERVER['PHP SELF] 义 全 局 变量 。 记 录 
$ GET["] 义 全 局 变量 。 记录 HTTP GET. 方法 
$ POST["] T 义 全 局 变量 。 记 录 HTTP POST 方法 发 


2 x 
行 的 PHP 文件 名 
送 的 于 
Alt e: 





















TE 





































$name 记录 提交 表单 后 “昵称 ”文本 框 中 输入 的 文本 
Semail 自 定义 变量 。 记 录 提 交 表单 后 “email” 文 本 框 中 输入 的 文本 
Sbtitle 自 定义 变 量 。 记 录 提 交 表 单 后 “主题 ”文本 框 中 输入 的 文本 
$msg 自 定 义 变量 。 记 录 提 交 表 单 后 “内 容 ” 文 本 框 中 输入 的 文本 
Saction 录 提 交 表 单 后 按钮 的 名 称 

Sconnection 记录 连接 数据 库 的 句柄 

Squery SQL 命令 “| 自 定 义 记录 SQL 命令 

Sresult 查询 数据 集 | 自 定义 变量 。 记 录 执 行 SQL 命令 后 的 返回 结果 








Serr 字符 串 自 定义 变量 。 记 录 提交 后 的 提示 信息 





Q 程序 中 用 到 的 函数 详解 如 表 6.3 PET. 


PHP 动态 网 页 设计 与 制作 案例 教程 (第 己 版 ) 


R63 程序 中 用 到 的 函数 













函数 m 法 
isset() | 参数 取 变 量 格式 的 字符 串 型 
服务 器 名 ,用 户 名 ,密码 ,数据 库 名 
连接 数据 库 的 标识 句柄 ,SQL 命令 
连接 数据 库 的 标识 句柄 








系统 函数 。 当 参数 为 变量 时 返 [ 
MySQL 函数 。 连 接 到 指定 的 数据 库 服务 器 
MySQL 函数 。 执 行 SQL 命令 
MySQL 函数 。 关 闭 数据 库 文件 
Date /Time 函数 。 返 回 当前 的 日 


true 








mysqli_connectO | E 
mysqli_query() | 
mysqli_close() | 























数 


now() 


期 和 时 间 





© 程序 中 用 到 的 SQL 语句 详解 如 表 6.4 所 示 。 
表 6.4 程序 中 用 到 的 SQL 命令 
命令 格式 


$9 X 





set names 'utf8' 设置 数据 库 的 





符 集 为 utf8 





INSERT INTO guestlist(name,msg,email,btitle,btime) 


" Pus oues - Me Eat max 
values('Sname,'$msg'/Semail'/'Sbtitle"| CURRENT TIMESTAMP) 向 数据 表 guestbook 的 表 尾 追加 记录 





图 对 程序 中 各 行 代码 的 解读 。 
第 2 一 10 行 : 初始 化 自 定义 变量 。 未 提交 表单 前 ， 消 为 空 ; 提交 后 获取 表单 中 对 应 的 输入 数据 。 
第 11 一 30 行 : 对 用 户 提交 表单 后 的 处 理 。 分 :3 种 情况 : 
第 11 一 12 行 : 当 用 户 单 击 了 “放弃 ”按钮 后 ， 刷 新 页 面 后 立即 返回 bbsindex.php. 
第 13 一 30 行 : 当 用 户 单 击 了 “提交 " 按 乌 后 ， 需 要 对 输入 检查 .其 中 
第 14 一 25 行 : 当 用 户 填写 的 稿 息 有 效 ( 都 不 空 ) 时 , ,需要 连接 数据 库 、 向 数据 表 写 入 相关 
关闭 数据 库 和 连接 、 设 置 成 功 提交 的 反馈 信息 ， 最 后 刷新 页 面 ，3 秒 后 
返回 bbsindex.php， 同 时 带 回 反馈 
6 一 29 行 ; 用 户 没有 完整 填写 
同时 带 回 反馈 è 
hF EE? GEB reset 类 型 ， 当 单 击 它 时 从 会 擦 除 所 有 文本 框 信息 。 
第 35 一 49 行 :\ 用 表格 布局 页 面 ， 表 单 提交 的 处 理 程序 就 在 本 页 面 进 行 。 
第 51 行 : 显示 反馈 信息 Serr。 


(4) 把 文件 write.php 以 rewrite.php 为 文件 名 另存 在 文件 夹 bbs 下 。 
(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 修 改 代码 如 下 。 


«?php 
Saction-"";$msg-"";S$name-"";S$email-"";S$bserial-"";$err-""; 
if(isset($ GET['err'])) $err-$ GET['err']; 
if(isset($ GET['serial'])) Sbserial-$ GET['serial']; 
include once("sys conf.inc"); 
// 建 立 与 MYSQL 数据库 的 连接 
$connection-mysqli connect ($DBHOST, $DBUSER, $DBPWD, $DBNAME) or 
die ("无 法 连接 数据 库 !") ; 
mysqli_query ($connection, "set names 'utf8'"); / /设置 字 符 集 
$query-"SELECT * FROM guestlist WHERE serial=$bserial"; 
$result-mysqli query ($connection, $query) or die (" 读 取 数据 失败 ") ; 
// 查 询 本 页 留言 主题 信息 














,设置 出 错 的 反馈 信息 并 刷新 页 面 ，2 秒 后 返 






B 
* 
* 





$row-mysqli fetch array($result); 
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$btitle=$row['btitle']; 

$p=0; $pp="bbsviewinfo. php"; 

if(isset($ GET['p'])) $p=$_GET['p']; 

if ($p==1) { 
$name-$ SESSION['name']; 
$email-"admin8localhost.com"; 
$pp-"adminviewinfo.php"; 

) 

if(isset($ POST['action']))( 
Saction-$ POST['action']; 
$name-$ POST['name']; 
$email-$ POST['email']; 
$msg-$ POST['msg']; 





) 
if ($action==" 放 弃 ") 
echo "<meta http-equiv=\"Refresh\" content=\"0;url=",$pp."? 
serial=".$bserial."\">"; 
else if ($action==" 提 交 "){ 
if ($name!="" && $email!-"" && $msg!=""){ 
// 向 服务 器 发 送 查 询 请 求 
$query-"INSERT INTO replylist (name,btime,msg,email,bserial) 
values('$name',CURRENT TIMESTAMP, '$msg','$email','$bserial')"; 
Sresultemysqli query ($connection, $query) or die (" 存 入 数据 库 失 败 ") ; 
mysqli_close ($connection) or die(" 无 法 断 开 与 数据 库 的 连接 ") ; 
S$err=" 回 复 留言 成 功 ! &nbsp; &nbsp; &nbsp; &nbsp; 3 秒 后 自动 返回 . Nn"; 
echo "<meta http-equiv-'Refresh' content-'2;url-z".$pp."? 
serial-".$bserial."'»"; 











if T ! &nbsp; &nbsp; &nbsp; snbsp; 信 息 不 全 ! 昵 称 、 邮 箱 、 主 题 
和 内 容 是 必须 填 
echo "«meta http-equiv-'Refresh' content-'2;url-".$ SERVER['PHP 
SELF']."?err-$err& serial-$bserial'»"; 
) 
) 
require ("bbshead.php"); 
2» 
«div id="bt"> 回 复 留言 «hr /»«/div» 
<div id="bd"> 
«form method-"post" action-"«?php echo $ SERVER['PHP SELF']."? 
serial-$bserial &&p-$p";?»"» 
«table width-"100 border-"0" cellspacing-"0" class-"tdl"» 
<tr><td align-"right"»&nbsp;HWü&nbsp; fk: &nbsp«/td» 





<td><input name="name" type="text" value-"«?php echo $name; ?>" 
size="45" maxlength="20"></td> 
<td align="right">Email:&nbsp</td> 





<td><input name="email" type="text" value="<?php echo $email; ?>" 





o 
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size-"48" maxlength-"20"» «/td» «/tr» 
<tr><td align-"right"»&nbsp; ¥&nbsp; $: &nbsp</td> 
<td colspan="3"><input name-"btitle" type="text" value="<?php 
echo $btitle; ?>" size=" 93" maxlength="80" readonl readonly" /»«/td»«/tr» 
<tr><td align="right">&nbsp; 内 &nbs: &nbsp</td> 






<td colspan="3"><textarea name="msg" cols="85" rows="8"> 
</textarea></td></tr> 
<tr><td align="center" colspan="4"><input type="submit" name="action" 
value=" 提 交 "> 
<input type-"reset" value- 
value=" 放 弃 "> 





"><input type-"submit" name-"action" 


</td></tr> 
</table> 
</form> 
</div> 
«div id="err" align="center"><?php echo $err; ?»«/div» <!-- 提 示 信息 
显示 区 域 --> 
<hr/> 
<iframe scrolling-"no" width="780" height="70" src-"bbsbottom.html" 
0" align="center" > 





marginwidth="0" marginheight="0" border="0" frameborder= 
不 支持 </iframe> 

</div> 

</body> 
</html> 


(6) 保存 文件 。 





d RBMA 


根据 留言 主题 回复 留言 . 因此 , 需要 传递 留言 序列 号 . 又 因为 户 和 管理 员 都 有 回复 留言 的 权限 ， 
所 以 还 要 传递 权限 数据 ， 以 便 回复 后 能 返回 所 在 的 页 面 。 数据 传递 通过 GET 方式. 同时， 当 回 复 留言 时 ， 
不 需要 用 户 再 输入 主题 ， 因 此 需要 通过 留言 序列 号 读 出 对 应 的 主题 数据 ， 直 接 显示 在 主题 文本 框 中 ， 用 户 
输入 的 信息 和 留言 序列 号 写 入 数据 表 replylist 中 . 

第 7~12 行 : 连接 数据 库 ， 读 出 留言 序列 号 对 应 的 信息 ， 获 取 主 题 数 据 $btitle。 

第 13 一 19 £f: 用 预定 义 全 局 变量 $_GET 获取 用 户 类 型 数据 S$p，1 为 管理 员 ，0 为 普通 用 户 。 根 据 用 

户 类 型 设置 返回 的 页 面 Spp。 
第 31 一 32 行 : 把 回复 的 数据 写 入 数据 表 replylist. 
第 46~60 行 : 表单 中 的 文本 行 显示 相关 的 数据 。 


6.34 浏览 留言 主题 页 
代码 文件 : bbsview.php. adminview.php 








(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


1 <?php 





2 Şpage=1; nineste 
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if(isset($ GET['page'])) $page-$ GET['page']; 

include once("sys conf.inc"); 

$connection-mysqli connect ($DBHOST, $DBUSER, $DBPWD, $DBNAME) or die(" 
无 法 连接 数据 库 ! ") ; 

mysqli query($connection,"set names 'utf8'"); // 设 置 字符 集 

$query-"SELECT * FROM guestlist WHERE flag-'Y' ORDER BY btime DESC"; 

$result-mysqli query($connection,$query) or die(" 读 取 数 据 失败 "); 

$count-mysqli num rows($result);  // 统 计 留 言 主题 信 息 

// 制 作 信息 条 

$bbsinfostr=" 目 前 留言 板 共有 " . $count." 个 留言 主题 。"; 

if($page«-0||$count--0) $page=1; 








$msgPerPage=2; // 设 置 一 页 中 显示 的 最 多 记录 数 
$start-($page-1)*$msgPerPage; ， // 设 置 每 页 开始 的 记录 序号 -1 
$end-$startt$msgPerPage; // 设 结束 的 记录 序号 


if($end>$count) S$end=$count; 
$totalpage=ceil ($count/$msgPerPage); 
if($count>0) $bbsinfostr.=" 本 页 列 出 了 第 ". (Sstart*1)." 至 ".$end." 个 。"; 
/7 制作 页 导航 
if ($page>1) $numestr="<a href=".$ SERVER['PHP SELF']."?page=". ($page-1). 
"> 上 一 页 </a> "."&nbsp|&nbsp"; 
for ($i=1; ($i<=$totalpage);$i++){ 
if ($i==$page) $numestr=$numestr.$i; 
else $numestr=$numestr."<a href=".$ SERVER['PHP SELF']."?page=$i>". 
$i."X/a»"; 
if(Si!-$totalpage) S$numestr.-"&nbsp|&nbsp"; 
) 
if (Spage« ($totalpage)) 
$numestr-$numestr."&nbsp|&nbsp«a 
href-".$ SERVER['PHP SELF']."?page-".($page*1l)."» F—Ji«/a»"; 
require once ("bbshead.php"); 
?» 
«div id="bt"> 查 看 留言 «hr /»«/div» 
<div id="err"><?php echo $bbsinfostr;?></div> 
<div id="bd"> 
«table width="100%" border-"1" cellspacing-"1" class-"tdl"» 
«tr align="center" id-"bitem"»«td» £ &nbsp; &nbsp; fil «/td»«td» Jl 
&nbsp; &nbsp; </td> 
<td> 发 帖 时 间 </td><tq> 回 复 次 数 </td></tr> 





<?php 
Squery-"SELECT * FROM guestlist WHERE flag-'Y' ORDER BY btime DESC LIMIT 
$start, $msgPerPage"; 
$result-mysqli query ($connection, $query) or die(" 读 取 数 据 失败 ") ; 
// 查 询 本 页 留言 主题 信息 
while($row-mysqli fetch array(Sresult))( // 输 出 留言 主题 
// 格 式 化 时 间 输 出 
$dbdate-$row['btime']; 
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$year-substr ($dbdate, 0,4) ; // 获 取 年 

$month-substr($dbdate,5,2); // 获 取 月 

$day-substr ($dbdate, 8,2); // 获 取 日 

$hour=substr ($dbdate,11,2); // 获 取 小 时 

$min=substr ($dbdate,14,2); // 获 取 分 钟 

$sec-substr ($dbdate,17,2); // 获 取 秒 

$time=$year." 年 ". $month." 月 ".$day." 日 ".$hour." 时 ".$min." 分 ".$sec." 秒 "; 
// 输 出 一 条 留言 主题 的 


echo "<tr align='center'><td><a href-'bbsviewinfo.php?serial-".$row 





['serial']."'» ".$row['btitle']."«/a»«/td»"; 
echo "«td»".$row['name']."«/td»«td»".Stime."«/td»"; 
$query-"SELECT * FROM replylist WHERE (flag-'Y' and bserial-'".S$row 
['serialt].""y"s 


$resultl-mysqli query($connection,$query) or die(" 读 取 数据 失败 ") ; 
$replynum-mysqli num rows ($resultl); 
echo "«td»".S$replynum."«/td»«/tr»"; 
) 
mysqli close($connection) or die(" 无 法 断 开 与 数据 库 的 连接 ") ; 
R> 
</table> 
</div> 
<div id="err" align="center"><?php echo $numestr; ?></div><hr/> 
<iframe scrolling="no" width="780" height="70" src="bbsbottom.html" 
marginwidth="0" marginheight="0" border="0" frameborder="0" align="center"> 
不 支持 </iframe> 
</div> 
</body> 
</html> 


(3) 把 文档 以 5bsview.php 为 文件 名 保存 在 文件 夹 bbs F- 





[m 
Miragi 


(D 程序 中 用 到 的 变量 详解 如 表 6.5 所 示 。 


表 6.5 程序 中 用 到 的 变量 



















变量 名 


取 值 
数据 表 中 的 数据 


含 
自 定义 变量 。 记 录 guestlist 数据 表 查 询 数据 集合 


义 





$result, $result2 






























| 
Srow | 数组 自 定义 数组 变量 。 记 录 查 询 数据 集中 的 一 条 
Sbbsinfostr | 字符 串 i 条 上 的 文本 
$count | 整数 记录 guestlist 中 记录 的 个 数 
Spage | 记录 分 页 显示 的 当前 页 码 

| 


$msgPerPage 
Sstart,Send 


记录 一 页 中 显示 的 最 多 记录 数 
手 页 开始 和 结束 的 记录 序号 
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( 续 ) 
变 量 名 $ x 
Stotalpage 。 记 录 总 页 数 
Sdbdate 。 记 录 每 条 记录 的 发 帖 时 间 


t。 分 别 记录 时 间 字 段 time 中 的 年 月 日 
。 分 别 记录 时 间 字段 time 中 的 时 分 秒 


$year | $month |$day 
Shour | $min | $sec 








Stime 。 记 录 格 式 转化 后 的 时 间 
Sreplynum 。 记 录 replylist 中 记录 的 个 数 
Snumestr 量 。 记 录 页 导航 栏 上 的 文本 





Q) 程序 中 用 到 的 函数 详解 如 表 6.6 所 示 。 
表 6.6 程序 中 用 到 的 函数 
m m KOX 
mysql_fetch_array( ) | 函数 取 查 m A MySQL 函数 。 以 数组 返回 查询 数据 集中 的 记录 
ceil( ) 函数 取 数 值 系统 函数 。 对 数值 进行 收尾 处 理 


substr( ) 详 见 5.3 节 系统 函数 立 对 字符 串 取 子 串 
mysql num rows() | 函数 为 查询 数据 集 MySQL 函数 。 统 计 查 询 数 据 集中 记录 个 数 


© 程序 中 用 到 的 SQL 命令 详解 如 表 6.7 所 示 . 





表 6.7、 程 序 中 用 到 的 SQL 命令 
命令 格式 
SELECT * FROM guestlist WHERE flag="Y" 
ORDER BY btime DESC LIMIT S$start, $msgPerPage 


SELECT * FROM replylist WHERE(flag="Y" 
AND bserial-" Srow['serial]."") 


图 对 程序 中 各 行 代码 的 解读 。 
第 2 一 3 行 : 初始 化 自 定义 变量 。 
第 4 一 8 行 : 连接 数据 库 ， 查 询 数 据 。 
第 11~18 行 : 设置 信息 条 上 的 信息 $bbsinfostr。 
第 20 一 27 47: 设置 分 页 显示 信息 条 上 的 信息 Snumestr。 
第 28~63 行 : 页 面 设计 。 其 中 
第 31 行 : 显示 信息 条 上 的 信息 Sbbsinfostr。 
第 34 一 35 行 : 用 表格 组 织 查看 留言 主题 信息 的 表 头 。 
第 37 一 38 行 : 查询 数据 表 guestlist 中 的 留言 数据 集 。 
第 39 一 56 行 : 逐条 输出 留言 数据 。 
第 41 一 48 行 : 转化 时 间 格 式 为 XXXX 年 XX 月 XX 日 XX 时 XX 分 XX 秒 。 
第 50 一 51 行 : 按 行 输出 每 一 个 留言 主题 的 信息 。 
第 52 一 53 行 : 查询 表 replylist 中 每 个 主题 的 回复 数据 集 . 
第 54 行 : 获取 回复 留言 查询 数据 集中 记录 的 个 数 Sreplynum。 
第 55 行 : 把 回复 留言 查询 数据 集中 记录 的 个 数 Sreplynum 显示 在 对 应 的 单元 格 中 。 
第 61 行 : 显示 页 导航 栏 上 的 信息 文本 Snumestr. 


t x 
查询 表 guestbook 中 所 有 flag 是 Y 的 记录 并 按 
btime 的 降序 生成 数据 集 (从 $start 始 SmsgPerPage 条 ) 
查询 表 replylist 的 所 有 flag 4& Y 且 指 定 标 题 的 记 
录 并 生成 查询 数据 集 
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(4) 把 文件 bbsview.php 以 adminview.php 为 文件 名 保存 在 文件 夹 bbs 下 。 
(5) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 修 改 SO 行 、 增 加 56 行 和 在 35 行 增加 
如 下 代码 。 





<td> 发 帖 时 间 </td><td>E 











; &nbsp; A/ tr> 





echo"<tr align-'center'»«td»«ahref- ?serial-".$row 


['serial']."'»".$row['btitle']."«/a»«/td» 







(6) 保存 文件 。 


Mirasa 


限 可 以 删除 相同 留言 主题 ， 增 加 一 个 选项 列 






处 理 程序 为 delete.php。 
6.3.5 浏览 主题 留言 页 
代码 文件 ，bbsviewinfo.php、adminviewinfo.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 

$page=1; $numestr="";$bserial=""; 

if(isset($ GET['page'])) $page=$_GET['page']; 

if(isset($ GET['serial'])) $bserial=$ GET['serial']; 

include once("sys conf.inc"); 

$connection-mysqli connect ($DBHOST, $DBUSER, $DBPWD, $DBNAME) or die(" 
无 法 连接 数据 库 ! "); 


mysgli query($connection,"set names 'utf8'"); 





$query-"SELECT * FROM guestlist WHERE serial-'$bserial'"; 
$result-emysqli query ($connection, $query) or die (" 读 取 数 据 失 败 0") ; 
// 查 询 表 guestlist 的 记录 
$row=mysqli fetch array ($result); 
$query="SELECT * FROM replylist WHERE (flag-'Y' and bserial-'$bserial')"; 
$resultl-mysqli query ($connection, $query) or die (" 读 取 数 据 失败 1") 
// 查 询 表 replylist 的 记录 
$replynum-mysqli num rows($resultl);  // 统 计 回复 主题 信息 
// 制 作 信息 条 
$bbsinfostr=" 目 前 本 主题 共有 «font color-'red'»".$replynum."«/font» 条 留言 
回复 。"; 
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if($Spage«-0||$replynum--0) S$page-1; 


$msgPerPage-2; // 设 置 一 页 中 显示 的 最 多 记录 数 
$start=($page-1)*$msgPerPage; // 设 置 每 页 开始 的 记录 序号 
$end=$start+$msgPerPage; // 设 置 每 页 结束 的 记录 序号 


if($end»$replynum) $end-$replynum; 
$totalpage-ceil ($replynum/$msgPerPage); 
if(Send»0) Sbbsinfostr.-" 本 页 列 出 了 第 «font colors'blue'»".($start*1)." 
</font> 至 <font color-'blue'» ".$end." </font> 条 \n"; 
/1 制作 页 导航 条 
if ($page>1) $numestr="<a href=".$ SERVER['PHP SELF']."?page-". ($page-1). 
"gserial =". $bserial."> 上 一 页 |</a> &nbsp; | &nbsp; 
for($ ; ($i<=$totalpage); $i++) { 
if ($i==$page) $numestr=$numestr.$i; 
else $numestr=$numestr."<a href-".$ SERVER['PHP SELF']."?page-".$i. 
"&serial-". $bserial."»".$i."«/a»" 














if(Si!-$totalpage) S$numestr.-"&nbsp; |&nbsp; 
) 
if (S$page« (Stotalpage)) 
$numestr-$numestr."&nbsp;|&nbsp;«a href-".$ SERVER['PHP SELF']."? 
page=". ($page*l)."&serial-".$bserial."» F—Ji«/a»"; 





require once ("bbshead.php"); 
?> 





«div id="bt"> 留 言 作 
<div id="err"><?php echo $bbsinfostr;?></div> 
<div id="bd"> 
<table width="100%" borde cellspacing-"1" class="tdl"> 
«tr id="err"><td width-"30$" rowspan="3"> 留 言 序列 号 : <?php echo 
$row['serial'];?»«br /> 版 主 ; <?php echo $row['name'];?></td><td> 主 题 ; 
<?php echo $row['btitle'];?»&nbsp;&nbsp;&nbsp; &nbsp; 发 表 时 间 : <?php echo 
$row['btime']; ?></td></tr> 
«tr ><td> 内 容 : <?php echo $row['msg'];?»«/td»«/tr» 


<hr /></div> 





<tr><td id="err" align="right"><a href="mailto:<?php echo $row 
['email'];?>"> 邮 件 : 
<?php echo $row['email'];?»«/a»&nbsp; &nbsp; &nbsp; &nbsp; <a href-"rewrite. 
php?serial-«?php echo $bserial;?>"> 回 复 留言 </a></td></tr> 














<?php 

$s-"SELECT * FROM replylist WHERE (flag='Y' andbserial='".$bserial."') 
ORDER BY btime DESC LIMIT $start,$msgPerPage"; 

$result2-mysqli query($connection,$s) or die (" 读 取 数 据 失 败 3") ; 




















// 查 询 本 页 回复 留言 信息 
mysqli_close ($connection) or die(" 无 法 断 开 与 数据 库 的 连接 ") ; 
while($row2-mysqli fetch array ($result2)){  // 输 出 留言 主题 
echo "<tr><td width-'30$' rowspan='3'> 回 复 留言 序列 号 : " .$row2['serial']." 
<br/> 回复 者 : " .$row2['name'] ."</td><td> 发 表 时 间 : " .$row2['btime'] ."</td></tr>"; 
echo "<tr><td> 内 容 : ".$row2['msg']."«/td»«/tr»"; 
echo "<tr><td align-'right'»«a href="'mailto:".$row2['email']."'> 邮 件 :". 
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$row2['email']."«/a» &nbsp;&nbsp;&nbsp;&nbsp;«Xa href-'rewrite.php? 
serial=".$bserial."> 回 复 留言 </a></td></tr>"; 
} 
?> 
«/table» 
«div id-"err" align-"center"»«?php echo $numestr; ?»«/div»«hr/» 
bbsbottom.html" 
0" align-"center" > 






<iframe scrolling="no" width-"780" height-"70" sr: 
marginwidth-"0" marginheight-"0" border-"0" frameborder- 
不 支持 </iframe> 
«/div» 
</body> 
</html> 





(3) 把 文档 以 bbsviewinfo.php 为 文件 名 保存 在 文件 夹 bbs Fe 


ha 
— 


根据 留言 主题 查看 留言 
A guestlist FR, MAKÈ 


因此 ， 需 要 传递 留言 主题 数据 , 数据 传递 通过 GET 方式 . 版 主 信息 从 数据 
息 从 数据 表 replylist 中 提取 采用 分 页 技术 能 有 效 查看 回复 留言 的 信息 。 








(4) 把 文件 bbsviewinfo.php 以 adminviewinfo.php 为 文件 名 保存 在 文件 夹 bbs F- 
(5) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 修 改 第 41 和 49 行 代码 ， 如 下 所 示 。 


41 <?php echo $row['email'];?»«/a»&nbsp; &nbsp; &nbsp; &nbsp; «a 
href-"rewrite.php?serial-«?php echo $bserial; "> FHM 15/2 / ta 76x 


49 echo "<tr><td align='right'><a href='mailto:".$row2['email']."'> 邮 件 ; 
".$row2['email']."«/a» &nbsp; &nbsp; &nbsp; gnbsp;<a href-'rewrite.php?serial-" 
.Sbseriol. "EE iiia 


f='hide.php?bser 






K/ta»«/tr»"; 





(6) 保存 文件 。 


4 ragi 

第 41.49 41: 自 定义 变量 $p=1 表示 管理 员 身 份 ; 管理 员 的 权限 还 可 以 屏蔽 留言 , 处 理 程序 为 hide.php。 
6.3.6 ”管理 员 登 录 页 

代码 文件 : loginadmin.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
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«?php 
8$session start();  // 启 动 session 变量 ， 注 意 一 定 要 放 在 首 行 
require once ("bbshead.php") 

po 

<script language-"javaScript" type-"text/javascript"» 
function pdsr()í 

var id-window.frm.name.value; 

var pds-window.frm.psd.value; 

if(id--"")( 
window.alert ("管理 员 ID 不 能 为 空 "); 
window.frm.name.focus(); 

) 

else if(pds--"")1 
window.alert ("密码 不 能 为 





window.frm.psd.focus(); 


) 
</script> 
«div id="bt"> 身 份 验证 <hr /></div> 
<div id="bd"> 
<form name="frm" method="post" action="<?php echo $ SERVER 
['PHP-SELE'];?»2"- 
«table width-"100$" border 
<tr><td align-"right"»/& 





cellspacing-"0" class-"tdl"» 
蛙 员 gnbsp; &nbsp; </td> 





<td><input name="name" type=text size="35" maxlength="20"> </td></tr> 
<tr><td align="right"> 密 Enbsp;&nbsp; 码 gnbsp; &nbsp; «/td» 
<td ><input name="psd" type="password" size="20" /></td></tr> 
<tr><td align="center" colspan="2"><input name="err" type="hidden" 
value-"«?php echo S$err; ?>" /></td></tr> 


<tr><td align-"center" colspan="2"><input type-"submit" name-"action" 
新 输入 "> </tr> 








Value=" " onmousedown="pdsr ()" ><input type-"reset" value- 
</table> 
</form> 
<?php 
Saction-""; S$err-""; 


if(isset($ POST['action'])) ( 
$action-$ POST['action']; 
$name-$ POST['name']; 
$psd-$ POST['psd']; 
$err-$ POST['err']; 
) 
$1P m-$ SERVER['REMOTE ADDR']; ”// 通 过 IP 地 址 确定 管理 员 的 身份 
登录 ") { 
include once("sys conf.inc"); 
$connection-mysqli connect ($DBHOST, $DBUSER, $DBPWD, "member") or die (" 


无 法 连接 数据 库 ! "); 





if ($action 
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mysqli query($connection,"set names 'utf8'");  // 设 置 字符 集 
$sql="SELECT * FROM administer WHERE userid-'".$name."'"; 
$records-mysqli query ($connection, $sql); 

mysqli close($connection) or die (" 无 法 断 开 与 数据 库 的 连接 ") ; 


$rows-mysqli fetch array ($records) ; 





if(Spsd--$rows['password'] or $IP m==$rows['IP']){ 
$_SESSION['name' ]=$name; 
echo "<meta http-equiv='Refresh' content='0;url= adminview.php'>"; 


else $err=" Afi 





有 误 ， 请 重新 输入 。"; 


?» 
«/div» 
«div id-"err" align-"center"»«?php echo $err; ?»«/div» 
<hr/> 
<iframe scrolling-"no" width-"780" height-"70" src-"bbsbottom.html" 
marginwidth-"0" marginheight-"0" border-"0" frameborder-"0" align="center"> 
不 支持 </iframe> 
</div> 
</body> 
</html> 





(3) 把 文档 以 loginadmin.php 为 文件 名 保存 在 文件 夹 bbs F. 





6.3.7 ”屏蔽 和 删除 留言 页 


代码 文件 : hide.php、delete.php 





(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签， 切换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


?php 

$sno-0;$bserial-""; 

if(isset($ GET['serial'])) $sno-$ GET['serial']; 

if(isset($ GET['bserial'])) $bserial-$ GET['bserial']; 

include once("sys conf.inc"); 

$connection-mysqli connect ($DBHOST, $DBUSER, $DBPWD, $DBNAME) or 
die (" 无 法 连接 数据 库 ! "); 

mysqli_query ($connection, "set names 'utf8'"); // 设 置 字符 集 

$query-"UPDATE replylist SET flag-'N' WHERE serial-$sno"; 

$result-mysqli query($connection,$query) or die(" 存 入 数据 库 失败 "); 

mysqli_close ($connection) or die ("无 法 断 开 与 数据 库 的 连接 "); 

echo "<meta http-equiv-'Refresh' content='0;url=adminviewinfo.php? 
serial=$bserial'>"; 





?» 


(3) 把 文档 以 hide.php 为 文件 名 保存 在 文件 夹 bbs 下 。 
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(OA 


屏蔽 留言 就 是 把 数据 表 replylist 相关 记录 中 字段 flag 的 值 设置 为 N, 相关 记录 采用 主键 确认 , 因此 需 
要 传递 serial 数据 。 处理 后 仍然 看 到 的 是 当前 页 面 ， 需 要 传递 留言 序列 号 Sbserial. 

第 8 行 : 设置 SQL 语句 更 新 replylist 表 指 定 serial 记录 的 字段 flag 的 值 为 N。 

第 11 行 : 根据 留言 序列 号 $bserial 刷新 adminviewinfo.php 页 面 。 

(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 

$sno=0; 

if(isset($ GET['serial'])) $sno=$_GET['serial']; 

include once("sys conf.inc"); 

$connection-mysqli connect ($DBHOST, SDBUSER, $DBPWD, $DBNAME) or 
die (" 无 法 连接 数据 库 ! ") 7 

mysgli query($connection,"set names 'utf8'"); // 设 置 字符 集 

$sqgl-"DELETE FROM guestlist WHERE serial-'$sno'"; 

mysqli query ($connection,$sq1); 

$sqgl-"DELETE FROM replylist WHERE bserial-'$sno'"; 

mysqli query ($connection,$sql); 

$sql-"ALTER TABLE guestlist DROP serial"; 

mysqli query ($connection,$sql); 

$sql-"ALTER TABLE guestlist ADD serial INT(11) NOT NULL AUTO INCREMENT 
COMMENT '， 聊 客 序列 号 "FIRST, ADD PRIMARY KEY (serial)"; 

mysqli query ($connection, $sql); 

$sql-"ALTER TABLE replylist DROP serial"; 

mysqli query ($connection,$sq1); 

$sql-"ALTER TABLE replylist ADD serial INT(11) NOT NULL AUTO INCREMENT 
COMMENT ' 回 复 者 序列 号 ' FIRST, ADD PRIMARY KEY (serial)"; 

















mysqli query($connection, $sql); 

mysqli_close ($connection) or die(" 无 法 断 开 与 数据 库 的 连接 "); 

echo "<meta http-equiv-'Refresh' content-'0;url-adminview.php'»"; 
?2 


(6) 把 文档 以 delete.php 为 文件 名 保存 在 文件 夹 bbs 下 。 





1 $V- 
一 案例 扩展 
6.8.8 ”调试 代码 


(1) 确认 bbsindex.php 等 文件 已 在 服务 器 访问 文件 夹 (如 ci\htdocs\wuya 或 ci\appservWwww\ 
wuya) 的 子 文件 夹 bbs 下 。 

(2) 启动 浏览 器 ， 输 入 http://localhost/wuya/bbs/bbsindex.php， 单 击 “ 转 到 ”按钮 ， 可 
见 如 图 6.3 所 示 的 效果 。 








(B hapVlocahosywuya/bbwybssndexphp FEIET 





Driers OUI rcs c) 


和 |SEERUA | 版 主管 理 | 返回 站 页 
欢迎 光临 留言 板 





Copyright@2016 wuyabook@com 无 尖 网 上 书店 上 权 所 有 
《中 华人 民 共和 国电 信 与 信息 服务 业务 经 各 许可 证 》 纺 号: 沪 ICPiExxxxxx 号 
WURA: 1020168 





图 6.3 留言 板 的 欢迎 界面 
(3) 单 击 “ 我 要 留言 ”链接 ， 进 入 写 留言 界面 。 输 入 相关 信息 ， 如 图 6.4 所 示 。 
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ab 
Copyright@2016 wuyabook@com 无 尖 网 上 书店 时 机 了 所 有 


(bc RHEGABGRURAISGRSZD AS: Picino 
INNEHAR: 26506 








NO 图 64 SHART 
CET 

O 当 填写 了 所 有 的 文本 框 后 再 单 击 “ 提 交 ” 按钮 时 ， 按 钮 下 方 出 现 提示 语 : “填写 留言 成 功 ! 二 秒 钟 
后 自动 返回 ,.” 并 在 2s 后 自动 返回 欢迎 界面 。 

© 当 没有 填写 任何 一 项 内 容 而 单 击 “提交 ”按钮 时 ， 按 钮 的 下 方 出 现 错误 提示 语 : “出 错 了 ! 信息 不 


全 ! 昵 称 、 邮 箱 、 主 题 和 内 容 是 必须 填写 的 !” 同 时 还 原 各 文本 框 ， 等 待 重 新 输入 。 
© 当 单 击 “ 放 弃 ” 按 钮 时 ， 将 返回 留言 板 的 欢迎 界面 ， 等 待 用 户 重 新 选择 。 


(4) 单 击 “ 查 看 留言 ”链接 ， 进 入 浏览 留言 界面 ， 如 图 6.5 所 示 。 


Lun 


O 单 击 某 主题 行 链接 将 在 新 窗口 中 浏览 该 主题 及 其 所 有 留言 信息 ， 如 图 6.6 所 示 。 

© 在 这 里 可 以 看 到 每 条 留言 的 详细 信息 ， 还 可 以 了 解 回复 者 的 相关 信息 及 回复 留言 。 当 单 击 “ 回 复 
留言 ”链接 时 ， 出 现 如 图 6.7 所 示 的 回复 留言 界面 。 

© 写 好 留言 ， 单 击 “ 写 好 了 ”按钮 ， 又 回 到 如 图 6.6 所 示 的 界面 。 


@y 
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c ISI m ET] 


& nies ^ Gu 说 出 你 的 


ATAA TARA HEES ET 


查看 留言 


目前 留言 板 闪 有 第 7 个 留言 主题 。 本 而 列 二 了 第 1 至 2 个 。 
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65 查看 留言 主题 界面 
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图 6.7 回复 留言 界面 
管理 ”链接 ， 进 入 管理 员 身 份 验证 界面 ， 如 图 6.8 所 示 。 
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68 ”管理 员 身 份 验证 界面 
S um 


O 填写 了 准确 的 信息 后 ， 单 击 “ 登 录 ” 按 钮 ， 进 入 如 图 69 所 示 的 管理 页 得 看 留言 主题 界面 


f WuYabook.com 


号 岗 上 书店 





Copia 无 尖 网 上 书 人 其 机 所 有 
por M PRU 
AMSUNABAM: NOH. 





XA ) 图 6.9 EUAWRAE 
[^] 单 击 共 主题 行 最 请 的 “删除 ”链接 ， 将 删除 该 主题 及 其 所 有 留言 信息 息 。 
G EHE ER, 将 在 新 窗口 中 浏览 该 主题 及 其 所 有 留言 信息 。 在 这 里 还 可 以 对 每 条 留言 进行 
屏蔽 留言 处 理 . 图 6.10 是 屏蔽 了 第 3 条 回复 留言 后 的 效果 。 
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图 6.10 留言 信息 界面 (屏蔽 第 3 条 回复 留言 ) 
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6 - c— Eel 


6.4 ”聊天 室 的 设计 


Earns 


6.4.1 ”聊天 室 的 架构 


聊天 时 ， 首 先 要 有 个 聊天 的 话题 ， 聊 天 室 要 有 聊天 主题 可 供 选择 。 

聊天 的 过 程 是 编辑 所 要 表达 的 信息 并 发 送 到 指定 的 显示 区 域 ， 供 在 线 的 网 友 浏 览 。 编 
辑 发 言 信息 是 最 主要 的 一 个 环节 ， 可 以 使 用 文字 输入 的 方式 ， 也 可 以 选择 一 些 固定 的 动作 
描述 或 图 片 表 达 ， 发 言 时 带 一 些 表情 会 更 加 生动 有 趣 。 本 案例 采用 两 种 发 言 模式 ， 一 种 是 
表情 加 文字 输入 ， 另 一 种 是 选择 动作 描述 。 , 


























本 案例 聊天 室 具 有 如 下 功能 ; KA 
(1) 登录 到 聊天 室 。 AN 
Q) 编辑 聊天 的 内 容 。 T 
(3) 显示 聊天 信息 。 AN 
(4) 聊天 信息 的 存储 。 ww 
聊天 室 的 工作 流程 图 如 图 6.11 所 示 。 |= 











图 6.11 聊天 室 的 工作 流程 
CET 


@ 用 户 向 服务 器 发 出 访问 请 求 。 

© 服务 器 根据 向 用 户 传送 欢迎 页 面 ， 并 要 求 用 户 登录 (输入 昵称 和 密码 )。 
@ 进入 聊天 室 页 面 : 从 数据 库 提 取 发 言 信 
图 编辑 聊天 信息 ， 发 送 到 数据 库 中 存储 。 

© 用 户 还 可 以 选择 浏览 聊天 信息 、 离 开 或 注销 等 操作 。 


642 ”聊天 室 的 设计 描述 
l. 逻辑 结构 设计 
根据 对 聊天 室 架构 的 描述 ， 可 得 其 逻辑 结构 ， 如 图 6.12 Bras. 
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Serial int(11) 
author varchar(20) 
chattime timestamp 
emotion varchar(20) 


action varchar(40) 


主页 chatindex.php 





四 水 聊天 记录 show.php 








提交 按钮 表单 


图 6.12 ”聊天 室 的 逻辑 结构 





2. 数据 库 设 计 






浏览 聊天 chatview.php 


离开 relogin.php 
注销 exit.php 















在 MySQL 数据 库 服务 器 上 建立 名 为 chat 的 数据 库 ， 其 中 包含 数据 表 chatroom 和 user, 
各 字段 的 定义 和 说 明 如 表 6.8 和 表 6.9 所 示 。 


表 6.8 数据 表 chatroom 字段 的 定义 和 说 明 

















varchar(5) 





REKER 
发 言 时 间 

表情 
发 言 动作 
XA 
RENK 









auto_increment 主键 












CURRENT_TIMESTAMP 















默认 为 black 




















字 R 类 型 说 明 备 注 
user_id int(11) 聊 客 序列 号 auto_increment 主键 
name varchar(20) 聊 客 姓名 
password varchar(20) 密码 
is_online varchar(1) 是 否 在 线 标志 默认 为 0 

3. 界面 设计 


(1) 聊天 室 主页 chatindex.php 的 页 面 规划 与 留言 板 中 的 管理 员 登 录 类 似 。 
(2) 聊天 室 页 mian.php 的 页 面 规划 如 下 所 示 。 其 中 的 样式 定义 在 chat.ess 中 。 














780x350( 上 部 ) 最 新 聊天 信息 显示 区 (show.php) 
780x480( 中 部 ) 写 聊天 信息 区 (say.php) 
780x70( 底 部 ) 版 权 信 息 





@r 


(3) 聊天 信息 显示 show.php 的 页 面 规划 如 下 所 示 。 
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Logo: 180x50 Banner: 600x50 
空白 ，780x10 








链接 菜单 : 780x50 





空白 : 780x5 





15 行 最 新 聊天 信息 显示 








(4) 写 聊天 信息 say.php 的 页 面 规划 如 下 所 示 。 
室 白 : 780x5 
文本 框 CHER) 发 言 按钮 表情 下 拉 列 表 动作 下 拉 列 表 文本 颜色 下 拉 列 表 
当前 在 线 人 : 复 选 框 组 ( 写 聊天 ) DARA 














(5) 浏览 聊天 信息 页 chatview.php 的 页 面 规划 如 下 所 示 。 





Logo: 180x50 Banner: 600x50 
空白 : 780 
链接 菜单 ，780x50 
空白 : 780x5 
标题 ，780x50 











分 页 E: 
序号 (5%) — 聊 客 (10%) 聊天 时 间 (20%) 聊天 内 容 
XXXX-XX-XX 
XXUXXUXX 
780x20- 顶 部 留 白 : 10p ”分 页 显示 信息 栏 





版 权 信息 


(6) 离开 聊天 室 页 relogin.php 的 页 面 与 主页 chatindex.php 类 似 ， 不 同 之 处 在 于 标题 栏 
的 下 方 无 提示 语 # 
(7) 注销 聊天 室 页 exit.php 的 页 面 与 主页 chatindex.php 相同 。 


6.5 ”聊天 室 的 实现 


虽 相 同 ， 为 了 使 代码 得 到 
现 。 网 页 中 的 图 像 需要 通 





由 对 聊天 室 的 设计 可 见 ， 聊 天 室 中 各 个 页 面 的 头 部 和 底 间 
重用 ， 把 它们 分 别 放 在 一 个 文档 中 。 通 过 CSS 对 网 页 表现 加 以 实 
过 图 形 处 理 软件 或 动画 软件 实现 。 

3 y 准备 工作 

(1) 确认 在 站 点 根 文 件 夹 已 建立 文件 夹 chat 作为 存放 与 聊天 室 相 关 的 文件 。 

(2) 确认 在 chat 文件 夹 中 已 建立 文件 夹 css 和 文件 夹 images。 

(3) 在 动画 软件 Ulead GIF Animator 中 制作 聊天 室 的 banner， 以 chat.gif 保存 在 文件 夹 


images。 


(4) 把 图 像 文 件 logo.gif 复制 一 份 存放 在 文件 夹 images 中 
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y 
"5 CSS 编 码 


代码 文件 ，chat.css 

chat.css 与 留言 板 的 bbs.css 基本 类 似 ， 只 是 bd 类 样式 有 所 不 同 。 
(1) 启动 Dreamweaver， 打 开 站 点 中 bbs\css\bbs.css。 

(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 修 改 代码 。 








#bd ( 
font-size: l4px; 
color: $F30; 
<!-- 要 修改 的 属性 --> 





(3) 把 文档 以 chat.css 为 文件 名 保存 在 文件 夹 chatess F» 


6.5.1 网 页 的 头 部 、 尾 部 和 系统 配置 文件 


F: chathead.php, chatbottom.html 和 sys conf.inc 





(1) 在 Dreamweaver 中 ， 新建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 ， 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmins-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 欢 迎 光临 wuya 聊天 室 </title> 
<link href="css/chat.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="app"> 
«div id="top"><img src-"images/logo.gif" width="180" height-"50" 
/><img src-"images/ chat.gif" width-"600" height-"50" /»«/div» 
«div align="center" class-"nemulink"» 
«a href="../index.php"> 返 回首 页 </a>&nbsp; | &nbsp; 
«a href="chatview.php"> 查 看 聊天 记录 </a>&nbsp; | &nbsp; 
«a href="main.php"> 查 看 聊天 室 </a>&nbsp; | &nbsp; 
«a href="relogin.php"> 离 开 </a>&nbsp; | &nbsp; 
<a href= "exit.php"> 注 销 </a></div> 


(3) 把 文档 以 chathead.php 为 文件 名 保存 在 文件 夹 chat F- 








link 标记 的 href。 
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(4) 在 Dreamweaver 中 ， 打 开 站 点 根 文件 夹 中 的 bottom.html。 
(5) 把 文件 以 此 chatbottom.html 为 文件 名 另存 在 chat 下 ， 并 修改 link 标记 中 的 href。 
(6) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(D) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
<!--sys_conf .inc: 系 统 配置 和 连接 数据 库 的 文件 -> 
«?php 

// 配 置 数据 库 全 局 变量 

$DBHOST-"localhost"; 

$DBUSER-"root"; 

$DBPWD-""; 

SDBNAME-"chat"; 

$mysqli- new mysqli ($DBHOST, $DBUSER, $DBPWD, SDBNAME) ; // 连 接 数 据 库 

if(mysqli connect errno()) //ik&&mysqli connect error() 新 特性 

die ("无 法 连接 数据 库 ! "). mysqli connect error(); 
$mysqli->query ("set names utf8"); 

















Marapi 


这 里 使 用 了 MySQLi 4//& P 4948 5 xT 8.09 77 kitik. E66 节 的 技术 要 点 ， 
第 4 一 7 行 : 配置 数据 库 的 爹 局 变量 ， 以 便于 阅读 和 修改 。 
第 8 一 11 行 : 连接 数据 库 ， 并 设置 字符 集 为 utf8，. 可 防 正中 文 乱码 ， 


6.5.0 ”聊天 室 的 主页 一 一 登录 页 
代码 文件 : chatindex.php、check_user.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 
$err=" 如 果 您 是 首次 登录 本 聊天 室 , 系统 将 自动 注册 您 的 信息 "; 
if(isset($ GET['err'])) Serr=$_GET['err'];// 初 始 化 自 定义 变量 
require once ("chathead.php"); 
?> 
<script language-"JavaScript"»  // 检 查 用 户 输 入 的 昵称 和 密码 不 能 为 空 
function checkvalid(){ 
if(document.frmLogin.user name.value--"")( 
alert (" 请 输入 昵称 ! ") 
document.frmLogin.user name.focus(); 
return false; 
) 


if(document.frmLogin.password.value--"")( 
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alert (" 请 输入 密码 ! ") ; 
document.frmLogin.password.focus(); 
return false; 
) 
return true; 
) 
</script> 
<div id="bt"> 请 您 注册 <hr /></div> 
«div class-"tdl" align="center"> 
<form name-"frmLogin" method="POST" action-"check user.php"» 
昵称 : &nbsp; <input type="text" name-"username" »&nbsp; &nbsp; 
密码 : &nbsp;<input type="password" name-"password" cols-"20"»&nbsp; 





&nbsp; 
«input type="submit" name-"cmdLogin" value=" 登录" onClick-"return 
checkvalid();"» 
</form> 
</div> 
<div id="err" align-"center"»«?pbhp.echo $err; ?></div> 
<hr/> 
<iframe scrolling="no" width="980" height="70" src="chatbottom.html" 
marginwidth="0" marginheight="0 border-"0" frameborder="0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html> 





(3) 把 文档 以 chatindex.php 为 文件 名 保存 在 文件 夹 chat 下 。 


ecd 
e. is 


使 用 JavaScript 检查 用 户 输 入 的 合法 性 是 在 客户 端 进行 的 ， 这 样 能 快速 地 让 用 户 明确 提交 表单 时 ， 文 
本 框 不 能 为 空 。 由 于 用 户 的 信 在 数据 库 中 ， 需 要 通过 PHP 验证 用 户 密码 输入 的 合法 性 。 
第 23 一 27 行 : 设置 表单 ， 表 单 的 处 理 程序 为 check_userphp。 其 中 
第 26 行 : 设置 提交 按钮 表单 ， 通 过 事件 onClick 触发 JavaScript 函数 checkvalid( ). 








(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(5) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 
Gsession start(); // 装 载 session 库 ， 一 定 要 放 在 首 行 
$user name-$ POST['username'];$password-$ POST['password']; 
// 获 取 表 单 提交 的 数据 
$ SESSION['username']-$user name; // 注 册 $user_name 变量 ， 注 意 没有 $ 符 号 
require once("sys conf.inc"); // 连 接 数据 库 


$sql="SELECT name,password FROM user WHERE name-'$user name 
$result=$mysqli->query ($sql)or die (" 查 询 数据 失败 1! ") 
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$rows-$result-»num rows; 
if($rows!-0)( // 对 于 老 用 户 
list ($name, $psd)=$result->fetch row(); 
if (Spsd--Spassword)( // 密 码 输入 正确 
$sql="UPDATE user SET is online-'1' WHERE name-'$user name' AND 
password-'$password'"; 
$result=$mysqli->query ($sql)or die(" 查 询 数 据 失 败 2! "); 
Smysqli->close() or die(" 关 闭 数据 库 失 败 ! ") ; 


echo "«meta http-equiv-'Refresh' content-'0;url-main.php'»" 





// 转 到 聊天 室 
} 
else( // 密 码 输入 错误 
$mysqli-»close() or die(" 关 闭 数据 库 失 败 ! "); > 
require ("relogin.php"); // 重 新 登录 O 
else( 





LRT, MEUS ACUTE 
$sql-"INSERT INTO Wan ain is online) VALUE('$user name', 
'$password',1)"; 

$result-$mysqli- >auery(Ssal)ar aie (查询 数据 库 关 败 1 PIE 

$mysgli-»close() or die(" 关 闭 数据 库 失败 ! "); 

echo "<meta http-equi 





Refresh' content-'0;url-main .php'»"; 


x 
?> 





(6) 把 文档 以 checksuserphp 为 文件 名 保存 在 文件 夹 chat F- 
6M 
Mirae 


把 表单 中 输入 的 昵称 信息 记录 在 会 话 变量 SESSION 中 。 对 新 老 聊 客 区 别处 理 ， 对 新 聊 客 只 要 将 其 信 
息 写 入 数据 库 ， 对 老 聊 客 要 验证 密码 输入 的 准确 性 ， 这 就 需要 读 取 数据 库 中 相应 的 数据 ， 
第 5 一 8 行 : 连接 数据 库 ， 并 查询 数据 。 其 中 


第 6 行 : 设置 SQL 语句， 查询 user 数据 表 中 的 name 字段 与 用 户 输入 的 昵称 的 name 比较 ， 验 证 身份 。 


第 7 行 : 使 用 PHP 的 MySQLi 类 的 方法 query0 获 取 查 询 数 据 集 记 录 在 变量 中 。 


第 8 行 : 使 用 PHP 的 MySQLi RESULT 的 属性 num rows 获取 查询 数据 集中 的 记 3 
第 9 一 21 行 : 









数量 。 
对 登录 过 聊 客 的 处 理 。 当 查询 集中 的 记录 数 不 为 0 时， 说明 该 登录 者 已 经 记录 在 数据 库 
中 .其 中 
第 10 行 : 使 用 PHP 的 MySQLi RESULT 的 方法 fetch_rowO 获 取 查 询 集中 的 记录 行 并 记录 在 列表 
数组 变量 

第 11 一 16 行 : 输入 密码 正确 时 的 处 理 。 其 中 

第 12 一 13 £r: 更 新 user 数据 表 中 登录 聊 客 的 on_line 字段 为 1， 确认 其 在 线 。 

第 14 行 : 使 用 PHP 的 MySQLi 类 的 方法 close() 关 闭 数 据 库 . 
第 15 行 : 刷新 main.php， 即 返回 聊天 室 
第 17 一 20 行 : 当 密 
2 


码 输入 错误 时 ， 关 闭 数 据 库 ， 并 进入 relogin.php， 即 重新 登录 。 
第 22 一 


27 行 : 对 新 登录 聊 客 的 处 理 。 将 其 数据 写 入 数据 库 中 并 确认 其 在 线 。 
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6.5.3 ”聊天 室 页 


代码 文件 : main.php、show.php、say.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP X 
(2) 单 击 “ 人 代码” 标签， 切换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 
(session start(); 





require once ("chathead.php"); 

include once("sys conf.inc"); // 选 择 数据 库 
?» 

<hr/> 

<div id="bd" class="tdl"><?php include("show.php"); ?></div> 

«div ><?php include("say.php"); ?></div><hr /»- 

<iframe scrolling="no" width-"780" height-"70" src 






hatbottom.html" 


marginwidth-"0" marginheight-"0" border-"0" frameborder- align="center"> 


不 支持 </iframe> 

«/div» 

</body> 一 
</html> 


(3) 把 文档 以 main.php 为 文件 名 保存 在 文件 夹 chat F- 


menegi 

由 于 聊天 室 需要 显示 当前 用 户 的 昵称 ， 因 此 需要 启动 session. 有 两 个 功能 区 域 ,都 有 数据 库 操作 ， 因 

此 需要 先 连接 数据 库 ; 最 后 关闭 数据 库 . 

第 7 行 : 设置 具有 bd 和 td 类 样式 的 聊天 信息 显示 区 域 ， 装 载 show.php。 此 处 显示 最 新 的 15 条 聊天 
信息 。 

第 8 行 : 设置 聊天 输入 区 域 ， 装 载 sayphp。 此 处 显示 给 入 聊天 的 各 种 方式 和 在 线 聊 客 信息 。 








(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 

«?php 
$sql-"select * from chatroom ORDER BY chattime"; // 按 时 间 降 序 查 找 所 有 聊天 记录 
$result-$mysqli-»query($sql) or die ("查询 数据 库 失 败 ! ") ; ”// 执 行 查 询 


$count=$result->num rows; // 取 得 查询 结果 的 记录 数 
if($count==0) $str-""; 
else( 

if($count«15) $l=$count; // 设 置 显示 最 新 记录 的 条 数 


else $l —15; 
$result-»data seek($count-$1);  ”// 移 动 记录 指针 到 倒数 第 $1 条 记录 
for ($i=1; $i<=$1; $i++) { // 显 示 最 新 的 记录 
list($cid, $cauthor, $cctime, $cemotion, $caction, $ccolor, $ctext 
=$result->fetch row(); 
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$str-"$cctime [".$cauthor."] "; 
if($ctext!-"" || $cemotion! 
$cemotion." 说 道 </font>: «font colo 





) $str.-"«font color-'green'»". 
$ccolor»".$ctext."«/font»«br/»"; 





else $str.-"«font color-'blue'»".$caction."«/font»«br/»"; 
echo $str; 





(6) 把 文档 以 show.php 为 文件 名 保存 在 文件 夹 chat 下 。 


Bi. ous 


本 段 代码 的 功能 : 从 数据 表 chatroom 中 提取 最 近 发 出 的 15 条 聊天 记录 \ 报 据 发 言 的 类 型 组 成 发 言 信 
义 指定 的 格式 显示 在 指定 的 区 域 中 。 
第 2 一 3 行 : 从 数据 表 chatroom 中 按时 间 降 序 查 询 数据 。 
第 4 行 : 使 用 PHP 的 MySQLi RESULT 的 属性 num rows 获取 查询 数据 集中 的 记录 数量 。 
第 7 一 8 行 : 根据 记录 总 数 设置 输出 记录 的 数目 。 若 小 于 j15， 则 输出 数目 为 记录 数 ; 否则 为 15， 
第 9 行 : 使 用 PHP 的 MySQLi RESULT 的 方法 data_seek() 移 动 记录 指针 到 指定 的 位 置 。 
第 10 一 16 行 : 输出 每 条 记录 。 其 中 
第 11 行 : 使 用 PHP 的 MySQLi RESULT 的 方法 fetch_row() 获 取 查 询 集中 的 记录 行 并 记录 在 列表 
中 的 变量 中 。 
第 12 行 : 把 发 言 时 间 和 作者 设置 到 输出 字符 串 中 。 
第 13 行 : 若 发 言 方式 为 “号 ” (发 言 内 容 和 表情 字段 不 空 )， 则 把 发 言 表情 和 发 言 内 容 设置 到 输出 
字符 串 中 ? 济 根 据 选择 的 颜色 修饰 发 言 内 容 》 
第 14 行 : 若 发 言 方式 为 “动作 ” (动作 字 艇 不 空 )> 则 把 发 言 动作 设置 到 输出 字符 串 中 ， 并 用 蓝 色 
修饰 动 帮 文 本 。 
第 15 行 :\ 把 输出 字符 串 显 示 到 浏览 器 中 。 








(7) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(8) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 

$slt text color="";$behavior="";// 初 始 化 自 定义 变量 

$emotion="";$action=""; $kick=""; $text=""; $author=""; 

if(isset($ POST['behavior'])) $behavior=$ POST['behavior']; 
// 获 取 表 单传 递 的 变量 

if(isset($ POST['emotion'])) $emotion-$ POST['emotion']; 

if(isset($ POST['action'])) $action-$ POST['action']; 

if(isset($ POST['kick'])) $kick=$ POST['kick']; 

if(isset($ POST['text'])) $text=$_ POST['text']; 

if(isset($ SESSION["username"])) Sauthor-$ SESSION["username"]; 

// 获 取 全 局 变量 
Sopti-Semotion; $opt2=$action ; 
if($author--"" && $behavior!-"") {// 处 理 注销 后 查看 聊天 室 ， 只 能 看 而 不 能 
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Serr" HARE, WEM! "; 
echo "<meta http-equiv='Refresh' content='0;url=chatindex.php?err 
=$err'>"; 
$ 
if(isset($ POST["slt text color"])) {// 选 择 字体 颜色 
Switch($ POST["slt text color"])( 
case "红色 ": Scolor-"red";break; 
case " 蓝 色 
case "灰色 
default: $color 


blue";break; 





gray";break; 
black"; 





) 
if ($behavior==" 发 言 "){ // RÄ 





if(Stext!-"" || $motion!=""){ 
$sq1-"INSERT INTO chatroom(author,chattime,emotion,action,color, 
text)"; 
$sql.-" VALUE('$author',CURRENT TIMESTAMP, '$emotion','','$color', 
'"$Stext')"; 
$result-$mysqli-»query($sql)or die (" 存 入 数据 库 失败 1! "); 
echo "<meta http-equiv-'Refresh' content='0;url=main.php'>"; 





f 


if($behavior- V/ 动 作 





if ($action! 
$sql-"INSERT INTO chatroom(author,chattime,emotion,action, color, 
text)"; 





$sqla=" VALUE('S$author',CURRENT TIMESTAMP, ' 
$result-$mysgli-»query($sqgl)or die(" 存 入 数据 库 


'Saction!,'','!)"; 
d 21"); 
echo "<meta http-equiv-'Refresh' content-'0;url-main.php'»"; 





) 
if ($behavior- 





踢 人 "){ // 踢 人 

$sql-"UPDATE chat.user SET is online-'0' WHERE user.name-'$kick'"; 
$result-$mysqli-»query($sql) or die (" 查 询 数据 库 失 败 3! "); 

echo "<meta http-equiv-'Refresh' content-'0;url-main.php'»"; 





?» 


«hr /» 





«form action-"main.php" method="POST" target-" self"» 

«table width-"100$" border-"1" align-"center" cellspacing- 
«tr» 

«td rowspan-"2" align="center"> 本 机 聊 客 <br/><?php echo $author;?»«/td» 


<td>gnbsp; 表 情 &nbsp;<select name-"emotion" size-"1"» <!-- 表 情 --> 





id="arr"> 


<option selected»«?php echo $optl; ?></option> 
«option» d 2Hlhi«/option» 
<option> 高 兴 地 </option> 


5i 

51 
52 
53 
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<option> 难 过 地 </option> 
<option> 傻 呆 呆 地 </option> 
<option> 惊 奇 地 </option> 
<option> 笑 睐 睐 地 </option> 
<option> 春 吞吐 吐 地 </option> 
<option> 愤 怒 地 </option> 
<option> 语 重心 长 地 </option> 
<option> 迷 惑 地 </option></select> 
&nbsp; 文 本 颜色 gnbsp;<select size-"1" name-"slt text color"> <!-- 









<option selected><?php echo $slt text color; ?></option> 
<option> 红 色 </option> 
<option> 蓝 色 </option> 
<option> 灰 色 </option> </select> 
<input name-"text" type="text" size="60" /»«/td» 
<td><input type="submit" name-"behavior" value-" nc tdostr» 
«tr»«td»&nbsp;z/fF&nbsp;«select size-"1" name-"action"» <!-- 动 作 --> 





<option selected»«?php echo $opt2 ?></option> 

<option> 双 手 抱 拳 ， 作 个 措 道 :- 各 位 朋友 请 了 ! </option> 

<option> 开 始 认真 考 虑 </ePtion> 

<option> 插 起 胸膛 , “大声 喊 道 ， 让 我 来 说 ! «/option» 

«option»jf TARJ 道 ， 还 不 明白 </option> 

不 ! 我 怎么 这 么 策 ! </option> 
<optiprz> 羔 婉 地 说 道 : 看 来 ， 我 还 得 再 看 看 书 ! </option> 
<GPtion> 捧 着 肚子 ， 喀 喀 哈哈 地 直 笑 得 两 眼 翻 白 ， 喘 不 过 气 米 。</option> 
<optiS6n> 快 乐 地 唱 道 ,我 明 自卫 </option> 
Kk5Btion> 深 深 地 叹 了 口气 </option></select></td> 

<td><input type="submit naine="behavior" value=" 发 送 " /»«/td»«/tr» 
<tr><td align="center"> 在 线 聊 客 </td><td>&nbsp; 












<?php 
$sql="SELECT * FROM user WHERE is_online='1' ORDER BY name"; 
// 查 询 在 线 用 户 
$result=$mysqli->query ($sql) or die ("查询 数据 库 失 败 4! t); ”// 执 行 查 询 
while ($row=$result->fetch_row()){  // 取 得 查询 结果 的 记录 数 
$uname-$row[1]; 
if ($uname!-$author) 





echo "<input type-'radio' name-'kick' value-'".$uname."'/» [".S$uname."] 
&nbsp;"; 
) 
Smysdqli->close();// 关 闭 数据 库 
?» 
«/td»«td»«input type="submit" name-"behavior" value=" A" /> «/ 
td»«/tr» 
</table> 


</form> 


(9) 把 文档 以 say.php 为 文件 名 保存 在 文件 夹 chat 下 。 
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Ais 


本 段 代码 的 功能 实现 在 指定 的 位 置 上 显示 当前 机 登录 的 聊 客 昵称 、 聊 天 的 两 种 方式 、 在 线 的 聊 客 ， 以 
及 对 发 言 的 提交 和 对 聊 客 的 踢 出 。 
O 程序 中 用 到 的 变量 详解 如 表 6.10 所 示 。 


R610 程序 中 用 到 的 变量 













变 量 名 m d $ X 

Soptl,Sopt2 列表 中 的 选项 | 自 定义 变量 。 记 录 表 情 和 动作 列表 中 被 选中 的 选项 
自 定义 变量 。 记 录 当 前 登录 的 聊 客 昵称 
预定 义 全 局 变量 。 记 录 当前 登录 的 聊 客 昵 称 
预定 义 全 局 变量 。 记录 提交 的 表单 数据 一 选择 的 文本 颜色 
预定 义 全 局 变量 。 记录 提交 的 表单 数据 一 输入 的 发 言 文本 
预定 义 全 局 变量 * 记录 提交 的 表单 数据 一 选择 的 发 言 
预定 义 全 局 变量 , 记录 提交 的 表单 数据 一 选择 的 发 言 动作 








Sauthor 
$ SESSION["username"] 
$ POST["'slt text color"] 
$. POST["text"] 
$. POST["motion"] 
$. POST["action"] 
































Scolor 

Sbehavior Semotion 
Stext Saction 记录 输入 的 发 言 内 容 、 动 作 列表 的 选择 
记录 文本 颜色 列表 的 选择 
自 定义 数组 变 医 记录 数据 表 中 的 一 行 记录 数据 


$slt_text_color 






Q) 程序 中 用 到 的 SQL 命令 详解 如 表 6.11 所 示 . 


表 6.11 程序 中 用 到 的 SQL 命令 
命令 格式 


INSERT INTO  chatroom(author,chattime,emotion,action,color, 
text) VALUE('Sauthor' CURRENT. TIMESTAMP.",'Saction',",") 


INSERT into chatroom(author,chattime,emotion,action,color;text) 
value('Sauthor, CURRENT TIMESTAMP,Semotion',"Scolor'/Stext") 


UPDATE chat.user SET is online- '0 WHERE user.name-'Skick 
SELECT * FROM user WHERE is online-'l' ORDER BY user id 


$ X 
息 (动作 ) 插 入 表 chatroom 中 
把 新 发 言 信息 ( 带 表 情 并 设置 了 颜色 的 
文本 ) 插 入 表 chatroom 中 
更 新 表 user 中 被 选中 用 户 的 在 
user id 降序 查询 表 user 中 的 在 



















© 对 程序 中 各 行 代码 的 解读 。 

第 11 一 14 行 : 对 选择 了 注销 链接 再 次 进入 聊天 室 的 或 没有 登录 的 聊 客 ， 设 置 无 发 言 权 限 。 

第 15 一 22 行 : 若 选择 了 文本 颜色 ， 则 把 选项 中 的 文本 转化 为 英文 名 称 。 

第 23 一 30 行 : 如 果 单 击 “ 发 言 ”按钮 ， 当 发 言 文本 或 发 言 表情 不 空 时 ， 就 把 这 些 信息 插入 数据 表 中 并 刷 
新 main.php( 可 看 到 此 条 发 言 )- 

第 31 一 38 行 : 如 果 选 择 了 发 言 动作 并 单 击 了 “发 送 ”按钮 ， 就 把 这 些 信 息 插入 数据 表 中 并 刷新 

main.php( 可 看 到 此 条 发 言 )。 
第 39 一 43 行 : 如 果 选 择 了 某 个 聊 客 昵称 前 的 单 选 框 并 单 击 “中 人 ”按钮 后 ， 就 把 该 聊 客 的 在 线 属性 


设 为 0 并 刷新 main php( 可 看 到 此 聊 客 昵称 消失 ). 
e, 
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第 46 一 94 行 : 设置 发 言 表单 。 处 理 程序 为 main.php， 目 标 在 被 浏览 窗口 中 。 以 表格 布局 各 个 项 目 ， 
前 两 行 设置 发 言 格式 ， 第 3 行 设置 在 线 聊 客 昵称 。 其 中 
第 49 行 : 合并 两 行 的 第 一 列 ， 显 OR 的 聊 客 昵称 。 
第 50 一 61 行 : 设置 表情 列表 ， 第 一 行 中 显 5 jiti. 
第 62 一 66 行 : 设置 输入 文本 的 颜色 列表 ， 第 一 行 中 显示 当前 的 选择 。 
第 67~68 行 : 输入 发 言 文 本 和 按钮 表单 ， 与 下 面 的 3 个 按钮 的 名 称 一 样 ， 以 便 对 提交 后 分 类 处 理 。 
第 69 一 80 行 : 设置 动作 列表 和 发 送 按钮 表单 。 
ae 设置 在 线 聊 客 列表 和 踢 人 按钮 表单 。 其 中 
一 89 行 : 逐条 记录 处 理 ， 获 取 每 行 中 第 一 个 字段 ( 聊 客 昵称 ). 
第 87 一 88 行 : 若 聊 客 昵称 不 是 当前 机 在 线 聊 客 昵称 ， 则 显示 在 单 选 按钮 后 。 


6.5.4 浏览 聊天 信息 页 





1 











代码 文件 : chatview.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php E 
Schatstr-"";$numestr-"";$page-1; 
if(isset($ GET['page'])) $page=$GET['page'];// 初 始 化 自 定义 变量 
include once("sys conf.ine");. 
$query-"SELECT * FROM chatroom "; 
$result-$mysqli-»query ($query) or aie Cibo Ke); 
$nysqli-»close() or die (" 无 法 断 开 与 数据 库 的 连接 ") ; 
Schatnum-$result-»num rows; 
$chatinfo8tr=* 目 前 聊天 室 中 共有 <foùt color-'red'»".$chatnum." </font> 
条 聊天 记录 2% 二 一 // 制 作 信息 条 000 
if ($page<=0 | | $chatnum==0) S$page=0; 
SmsgPerPage-10; 。// 设 置 一 页 中 显示 的 最 多 记录 数 
$start-($page-1)*$msgPerPage;  // 设 置 每 页 开始 的 记录 序号 
$end-$start*$msgPerPage; ， // 设 置 每 页 结束 的 记录 序号 
if($end»$chatnum) $end-$chatnum; 
Stotalpage-ceil(S$chatnum/S$msgPerPage); 
if($chatnum»0) $chatinfostr.=" 本 页 列 出 了 第 «font color-'blue'»".($start 
+1) ." </font> 至 第 «font color-'blue'» ".$end." </font> 条 。" 





require once("chathead.php"); 
?» 
«div id="bt"> 查 看 聊天 记录 <hr /»«/div» 
<div id="err"><?php echo $chatinfostr;?></div> 
<div id="bd"> 
«table width="100%" border-"1" cellspacing-"1" class-"tdl"» 
<tr align="center" id-err"»«td width="8%"> 序 号 </td><tqd width-"10$"» 
聊 客 </td> 





«td width="20s"> 聊 天 时 间 </td><td> 聊 天 内 容 </td></tr> 
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«?php 
for ($i=$start;$i<$end;$i++) {  // 输 出 聊天 信息 

$result-»data seek($i); 

list ($cid,S$cauthor,$cctime, $cemotion,$caction,$ccolor,$ctext) -$result 
-»fetch row(); 

if($ctext!- 
-$ccolor»".$ctext." «/font»«br/»"; 

else S$chatstr.-"«font color-'blue'»".$caction."«/font»«br/»"; 

echo "<tr><td align-V'centerV'»2".$cid."«/td»«td»".$cauthor."«/td»«td»". 
$cctime."«/td» «td »".$chatstr." </td></tr>";// 输 出 一 条 聊天 信息 





"" || $cemotion!="") $chatstr.=$cemotion." 说 道 : «font color 


$chatstr=""; 
} 
if ($page==$totalpage) 
for($j-$msgPerPage;$j» ($i-10*floor ($i/10) ) ;$j-=){X/ 一 页 中 记 
WW, 


echo"«tr»«td»&nbsp; «/td»«td»&nbsp;«/td»«td»&nbsp; «/td»«td»&nbsp; 





不 足 最 大 数 





«/td»«/tr»"; 
) 
// 制 作 页 导航 
if ($page»1) 
$numestr-"«a href-".$-SERVER['PHP SELF']."?page-".($page-1)."»]- 
-页 </a>&nbsp;| &nbsp;".$numestr; 
for($i-1; ($i<=$totalpage) ; $i++) { 
if ($i==$page) |$numestr.-$i; 
else $numestr.-"«a href=".$ SERVER['PHP SELF']."?page=$i>".$i."</a> "; 
if(Si«$totalpage) S$numestr-$numestr."&nbsp; |&nbsp;"; 
) 
if(Spage«$totalpage) $numestr.-"&nbsp;|&nbsp;«a href-".$ SERVER 
['PHP SELF']."? Page-".($page*t1)."» F—Ji«/a»"; 
?» 
«/table»«/div» 
<div id-"err" align-"center"»«?php echo "$numestr"; ?»«/div»«hr/» 
<iframe scrolling="no" width-"780" height-"60" src-"chatbottom.html" 





marginwidth-"0" marginheight-"0" border-"0" frameborder- align="center" > 


不 支持 </iframe> 
</div> 
</body> 
</html> 





(3) 把 文档 以 chatview.php 为 文件 名 保存 在 文件 夹 chat F- 


md 
LAGE S IR 


这 段 代 码 的 含义 参见 6.3 节 中 bbsviewinfo.php 的 代码 解读 . 
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6.5.5 ”离开 页 
代码 文件 :relogin.php 


(1) 在 Dreamweaver 中 ， 打 开 文 件 chatindex.php。 
Q) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 修 改 代码 。 


<?php require once("chathead.php");?> 
<script language-"JavaScript"»  // 检 查 用 户 输入 的 昵称 和 密码 是 否 合 法 
function checkvalid(){ 
if(document.frmLogin.user name.value--"")( 
alert (" 请 输入 昵称 ! "); 
document.frmLogin.user name.focus(); 
return false; 
) 
if (document.frmLogin.password.value--"")( 
alert (" 请 输入 密码 ! "); 
document.frmLogin.password.focus(); 
return false; 
) 
return true; 
) 
«/script» 
«div ide"bt"»ijffé 





注册 <hr /></div> 
<div class-"tdl" align-"center"» 
<form name-"frmLogin" method="POST" action-"check user.php"» 
Wüfk:«input type-"text" name-"username" value-"«?php echo $ SESSION 
['username'];2?»" 
&H:«input type="password" name-"password" > 





«input type="submit" nàme-"cmdLogin" value=" 登 录 " onClick- "return 
checkvalid();"» 


«/form»«/div» 

«div id-"err" align="center"> 如 果 您 是 首次 登录 本 聊天 室 , 系统 将 自动 注册 您 的 信息 
</div> 
<hr/> 


<iframe scrolling="no" width-"780" height="70" src-"chatbottom.html" 
marginwidth="0" marginheight="0" border="0" frameborder="0" align="center" > 
不 支持 </iframe> 
</div> 
</body> 
</html 


(3) 把 文件 以 relogin.php 为 文件 名 保存 








AFK chat F. 
6.5.6 ”注销 页 
代码 文件 exit.php 


(1) 在 Dreamweaver 中 ， 





建 PHP 文档 。 


ee 
| 
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"S 








， 输 入 如 下 代码 。 





(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ” 视 


<?php 
@session start(); 
$user=$_SESSION['username']; 
require once("sys conf.inc"); 
$sql-"update user set is online-'0' where name='S$Suser'";// 更 新 用 户 的 在 线 属性 
$result-$mysqli-»query($sql) or die (" 查 询 数据 库 失 败 ! ") ; — // 执 行 查询 
$mysqli-»close(); // 关 闭 数据 库 
session destroy(); // 销 毁 本 次 会 话 (回收 会 话 数组 空间 ) 
echo "<meta http-equiv-'Refresh' content-'0;url-chatindex.php'»"; 
Ræ 


(3) 把 文档 以 exit.php 为 文件 名 保存 在 文件 夹 chat 下 。 


全 


本 段 代码 实现 了 修改 要 注销 聊 客 的 在 线 属性 、 销 毁 本 次 的 俗话 谈 量 和 定向 到 聊天 室 的 首页 。 





^. 
MT. 


6.5.7 ”调试 代码 

(1) 确认 chatindex.php 等 文件 已 在 服务 器 访问 目录 (如 ei\htdocs\wuya 或 c:\Appservwww\ 
wuya) 的 子 目 录 chat 下 。 

(D 启动 浏览 器 ， 输 入 :_http://localhost/wuya/chat/chatindex.php， 单 击 “ 转 到 ”按钮 ， 
可 见 如 图 6.13 所 示 的 效果 。 


| pfocalhos mye 


P-O B rcasateoy WR 


$t 8 HW» AE Welcome 


SONTI SANER HEWES [RE HA 





如果 您 是 首次 于 录 


Copyright@2016 wuyabook@com 无 源 网 上 书店 版 权 所 有 
人 * 中 华人 民 共 和 国电 信 与 信息 服务 业务 经 营 许可 证 了》 编号 : 沪 ICP 证 xxxxxx| 
建议 浏览 器 分 辩 率 : 1024x768 





图 6.13 ”聊天 室 的 主页 页 面 
(3) 在 表单 中 输入 姓名 和 密码 ， 单 击 “ 登 录 ” 按 钮 ， 可 见 如 图 6.14 所 示 的 效果 。 
«t 说 明 
© 若 有 一 个 文本 框 中 没有 输入 或 再 次 登录 时 密码 输 错 ， 则 会 弹出 警示 框 。 
Q) 在 如 图 6.14 所 示 的 页 面 中 ， 可 选择 设置 表情 和 文本 颜色 后 ， 再 输入 文本 的 “发 言 ”方式 ， 或 选择 
动作 的 “ 方式 进行 聊天 交互 。 
© 同时 页 面 下 方 还 可 见 在 线 的 聊 客 ， 不 喜欢 可 以 “ 踢 人 "。 








g 
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图 6.14 聊天 室 界 面 
(4) 单 击 “ 查 看 聊天 记录 ”链接 ， 可 见 如 图 64 m 
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图 6.15 单 击 “ 查 看 聊天 记录 ”链接 后 的 界面 
(5) 单 击 “ 离 开 ” 链 接 ， 可 见 如 图 6.16 所 示 的 效果 。 
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图 6.16 单 击 “离开 ”链接 后 的 界面 











(6) 单 击 “ 注 销 ” 链 接 ， 回 到 如 图 6.13 所 示 的 登录 界面 。 

(7) 单 击 “ 查 看 聊天 室 ” 链 接 ， 可 见 如 图 6.14 所 示 的 聊天 室 页 面 。 
区 明 

在 单 击 “注销 ”链接 后 再 单 击 “ 查 看 聊天 室 ” 链 接 ， 可 见 本 机 的 聊 客 为 空 ; 在 单 击 “离开 ”链接 后 再 
单 击 “ 查 看 聊天 室 ” 链 接 ， 可 见 本 机 的 聊 客 不 空 ; 这 就 是 “离开 ”与 “注销 ”的 区 别 ， 如 图 6.17 所 示 。 


动作 
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(a) “查看 聊天 室 ” 链 接 界面 (离开 ) (b) “查看 聊天 室 ” 链 接 界 面 (注销 ) 
图 6.17 “查看 聊天 室 ” 链 接 界面 











\【 区 技术 要 点 
6.6 PHP 访问 数据 库 
6.6.1. PHP 访问 数据 库 的 机 制 | 
l. PHP 访问 数据 库 的 过 程 
数据 存放 在 数据 库 服务 器 中 。PHP 提供 了 一 组 函数 实现 对 数据 库 的 访问 ，SQL 命令 作 
为 字符 串 成 为 函数 的 参数 。BHR 访问 数据 库 的 机 制 示意 如 图 6.18 所 示 。 







用 户 请 求 数据 SQL 查询 语句 
PHP 函 数 或 扩展 


查询 返回 数据 集 











MySQL 
数据 库 管理 系统 


Internet 


系统 返回 数据 








Web 服 务 器 
PHP 





6.18 PHP 访问 数据 库 的 机 制 示意 图 
PHP 访问 数据 库 的 流程 包括 以 下 步骤 ， 如 图 6.19 所 示 。 





























图 6.19 PHP 通过 MySQL 扩展 访问 数据 库 的 流程 示意 图 
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(1) 连接 数据 库 服务 器 。 

(2) 选择 数据 库 。 

(3) 管理 或 查询 数据 表 。 

(4) 反馈 查询 结果 。 

(5) 关闭 数据 库 。 

2. PHP 访问 MySQL 的 方式 

随 着 PHP 的 不 断 发 展 ，PHP 访问 MySQL 的 方式 也 在 不 断 更 新 。 目 前 ， 常 使 用 的 有 
MySQL 扩展 、MySQLi 扩展 和 PDO 操作 等 方式 。 


(1) MySQL 扩 





面向 过 程 的 接口 ， 
MySQL 扩展 
仅 提 供 了 面向 过 程 


支持 、 多 语句 执行 
MySQLi 扩展 





BOR FF RE M 


(2) MySQLi 扩 
的 高 级 特性 。MySQLi 扩展 包含 在 PHP. 5 RARAP MySQLi 扩展 有 一 系列 的 优势 ， 不 























展 。MySQL 扩展 是 PHP 访问 MySQL 数据 库 的 早期 扩展 。 它 提供 了 一 个 
并 且 是 针对 MySQL 4.1.3 或 更 早 版 本 设计 的 。 可见， 如 果 使 用 MySQL 4.1.3 


或 更 新 的 服务 端 版 本 ， 建 议 使 用 MySQLi 扩展 替代 它 。 


4 源 代码 在 PHP 扩展 目录 的 ext/mysql 下 < 
展 。 又 称 为 MySQL 增强 扩展 。 可 用 于 使 用 MySQL 4.1.3 或 更 新 版 本 中 新 








的 接口 ， 还 提供 了 面向 对 象 接 日 ;相对 于 MySQL 扩展 ， 在 prepared 语句 
支持 、 事 务 支 持 、 增 强 的 调试 能 力 和 嵌入 式 服务 支持 等 方面 都 有 所 提升 。 
的 源 代 码 在 PHP 扩展 目录 的 ext/mysqli 下 。 


(3) PDO(PHP Data Object)J/ EZS e. PDO 为 PHP 访问 数据 库 定 义 了 轻 量 级 的 、 一 致 性 
的 接口 ， 它 提供 了 
PDO 驱动 中 的 一 个 


-个 数据 库 访问 抽象 层 。PDO 由 MySQL 了 驱动， 而 MySQL 驱动 是 众多 
它 是 基于 PHP 扩展 框架 实现 的 PDO' 简 化 了 数据 库 的 操作 并 能 够 屏 
异 ， 可 以 方便 地 进行 跨 数 据 库 程序 的 开发 ， 以 及 不 同 数据 库 间 的 移 












植 ， 是 将 来 PHP 在 数据 库 处 理 方面 的 主要 发 展 方向 。 
PDO 扩展 类 库 的 源码 在 PHP 扩展 目录 的 ext/pdo_mysql 下 。 
KR 6.12 比较 了 了 PHP 中 3 种 主要 的 MySQL 连接 方式 的 功能 。 


表 6.12 MySQL 配置 选项 



































特 ”性 PHP 的 MySQL 扩 展 | PHP 的 MySQLi 扩 展 | PDO MySQL API 
引入 的 PHP 版 本 3.0 之 前 5.0 5.0 
PHP 5.x 是 否 包含 是 是 是 
MySQL 开发 状态 仅 维护 活跃 在 PHP 5.3 中 活跃 
在 MySQL 新 项 目 中 的 建议 使 用 程度 不 建议 建议 - 首选 建议 
API 的 字符 集 支持 T 是 是 
服务 端 prepare 语句 的 支持 情况 f 是 是 
客户 端 prepare 语句 的 支持 情况 Tr T 是 
存储 过 程 支持 情况 m 是 是 
多 语句 执行 支持 情况 否 是 大 多 数 
是 否 支持 所 有 MySQL 4.1 以 上 功能 m 是 大 多 数 
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无 论 使 用 哪 种 方式 ， 都 要 确定 启动 了 相应 的 扩展 。 按 照 第 2 章 的 安装 和 配置 ， 需 要 修 








改 php.ini， 释 放 MySQL 扩展 、MySQLi 扩展 和 PDO 的 MySQL 扩展 及 如 表 6.13 所 示 的 配 
署 选 项 。 





表 6.13 php.ini 中 的 配置 选项 








名 称 Bo 认 dà x 可 更 m 
mysql.allow_persistent wj" 是 耕 允 许 MySQL 的 持久 连接 PHP INI SYSTEM 
mysgql.max, persistent "一 1" 每 个 进程 中 最 大 的 持久 连接 数目 | PHP. INI SYSTEM 
mysql.max_links "1" FEER d Kg Bc PHP INI SYSTEM 
mysql.trace_mode "0" SRERBUX. A PHP 4.3.0 起 可 用 | PHP INI ALL 
mysql.default_port NULL 默认 连接 数据 库 的 TCP 端口 号 | PHP INI ALL 
mysql.default_socket NULL 默认 的 socket 名 称 PHP INI ALL 
mysql.default host NULL 默认 的 服务 器 地 址 PHP_INI_ALL 
mysql.default_user NULL 默认 使 用 的 用 户 各 PHP. INI ALL 
mysql.default password NULL 默认 使 用 的 密码 PHP_INL ALL 
mysql.connect_timeout Ar — | 连接 超时 秒 数 PHP_INL ALL 
mysgli.allow. local infile win 允许 访问 PHP 本 地 文件 PHP_INLSYSTEM 
mysqli.reconnect "0" 连接 丢失 时 是 否 自动 重新 连接 PHP_INI_SYSTEM 
pdo_mysql.default_socket | "/tmp/mysql.sock" | 设置 Unix domain socket PHP INI SYSTEM 
pdo mysql.debug NULL 允许 调试 PDO_MYSQL PHP INI SYSTEM 

第 5 和 第 6 章 中 的 案例 分 别 用 到 了 MySQL 扩展 、MySQLi 扩展 的 面向 过 程 接口 、 


MySQLi 扩展 的 面向 对 象 接口 ,在 这 里 对 相关 技术 做 一 些 梳理 。 对 于 PDO 方式 ， 本 书 暂 未 
涉及 。 
PHP 操作 MySQL 函数 和 MySQLi 函数 和 类 的 属性 和 方法 可 分 为 如 下 几 类 。 
(1) 数据 库 操作 函数 如 表 6.14 所 示 。 
表 6.14 ”数据 库 操作 函数 
MySQLi 函数 MySQLi 函数 















E 能 说 昌 
MySQL 函数 (面向 过 程 ) (面向 对 象 ) 功能 说 明 
mysql. connect() | mysqli_connect() mysgli: construct() | 打开 一 个 到 MySQL 服务 端的 新 的 连接 





mysql. pconnect() | 永久 连接 MySQL 数据 库 服务 器 
mysql_close () | mysgli close() mysgli-»close() 关闭 先前 打开 的 数据 库 连 接 


mysqli_select_db() mysqli->select_db() 为 数据 库 查 询 选 择 默认 数据 库 








mysql_select_db () 














MySQL 函数 
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( 续 ) 






MySQLi 函数 MySQLi 函数 


(面向 过 程 ) (面向 对 象 ) mw wm 





mysql create db() 





创建 数据 库 





删除 数据 库 








mysql list dbs() 


获取 数据 库 名 








| 
mysql_drop_db() | 
| 
| 


mysql_list_tables() 


获取 数据 库 下 所 有 表 的 名 称 











mysql. tablename 


(2) 数据 表 操 人 


MySQL 函数 


mysql. query () 
mysql. db query() 
mysql affected rows() 
mysql insert. id() 








取得 表 名 


:函数 如 表 6.15 所 示 。 


表 6.15 数据 表 操作 函数 


MySQLi 函 MySQLi di? 
mysqli_query() 在 数据 库 上 执行 一 个 查询 
| ”人 “| 在 特定 的 数据 库 里 执行 SQL 语句 
mysali affected rows) 获取 前 一 个 MySQL 操作 受 影响 行 数 


mysgli insert id) 返回 最 后 一 次 查询 自动 生成 并 使 用 的 ID 





(3) 记录 操作 函数 如 表 6.16 所 示 。 


MySQL 函数 


mysql num fields() 
mysql fetch lengths() 
mysql num rows () 


mysql. data seek() 


X616 记录 操作 函数 


面向 过 程 EET Em 





mysqli num fields() | $mysgli fesult-^field count. | 获取 结果 集中 字段 数量 
$mysgli. result-»lengths 返回 结果 集中 当前 行 的 列 长 度 
S$mysqli_result->num_rows | 获取 结果 集中 行 的 数量 


mysqli_result->data_seek() | 将 结果 集中 的 指针 调整 到 任意 


mysgli. fetch. lengths() 
mysqli num rows() 


mysqli data seek() 








mysql fetch array() 


以 一 个 关联 数组 、 数 介 
mysqli_result->fetch_array( | 组 ， 或 者 两 者 第 有 的 方式 抓 取 





mysgqli fetch array() 








mysql. fetch assoc() 





结果 集中 的 一 行 
小 一 个 2 结果 
mysgli fetch assoc() mysgli result-^fetch. assoc() P^ à in EU 方式 抓 取 结 果 





mysql. fetch. field() 


mysgli fetch field() | mysqli result-^fetch field() | 返回 结果 集中 的 下 一 个 字段 








返回 一 个 代表 结果 集 字段 的 对 


mysqli_fetch_fields0) mysgqli result-^fetch fields() 





象 数组 
以 对 象 方式 返回 结果 集中 的 当 
mysql fetch object() | mysqli fetch object() | mysqli_result->fetch_objectO) d 方式 返回 结果 集中 的 当 
i 





mysql_fetch_row() 








以 一 个 枚 举 数组 方式 返回 结果 
集中 的 一 行 








mysgqli fetch row() mysgli result-^fetch row() 





mysql field. seek() 








设置 结果 集 指针 到 特定 的 字段 


mysql field seek() Fuat 
tj 


mysgli result-^ield seck () 
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( 续 ) 
MySQLi MySQLi ü " 
eed ined wem 
从 结果 集中 取得 和 指定 字段 关 
联 的 标志 
返回 结果 集中 指定 字段 的 长 度 
取得 结果 集中 指定 字段 的 字段 名 
取得 结果 集中 指定 字段 所 在 的 
表 名 
取得 结果 集中 指定 字段 的 类 型 
列 出 结果 集中 的 字段 
取得 结果 集中 的 数据 


MySQL 函数 





mysql_field_flags() 














mysql_field_len() 








mysql_field_name() 





mysql_field_table() 





mysql_field_type() 
mysql_list_fields() 








mysql_result() 
mysqli_result->free(). 

mysql free result() | mysqli_free_result() sgli result-»close. 释放 与 结果 集 相 关 的 内 存 
mysgli result-»free result 








(4) 错误 检查 函数 如 表 6.17 所 示 。 
56417. 错误 检查 函数 


mysql ermo() moss emeD1 £^ | ermo0 | Smysatizermo Ko | Smysqli>ermo [Xie ra "ett 

mysql error() 返回 最 近 的 函数 调用 产生 的 错误 描述 
返回 最 后 一 次 连接 调用 的 错误 代码 
返回 上 一 次 连接 错误 的 错误 描述 
返回 最 近 调用 函数 的 错误 列表 


6.6.2 ”连接 MySQL 数据 库 


与 连接 MySQL 数据 库 相 关 的 操作 包括 连接 到 MySQL 服务 器 .选择 数据 库 和 关闭 数据 
库 连 接 ， 其 中 还 要 考虑 对 错误 的 检查 和 报告 。 


1. MySQL 扩展 








示例 6_1_mysql// MySQL 4 RÈ 


«?ph| 
Š E ("localhost","root","");  // 连 接 MySQL 服务 器 
if(mysql errno()>0){ 
echo "<br />1. ".mysql errno().":".mysql error()."<br /»" ; // 检 查 错误 
exit(); 
} 
else{ 


echo "1. 数据 库 连 接 成 功 ! <br />"; 


oO 第 6 章 网 上 社区 设计 与 PHP 数据 库 访问 


© e NE 
mysql select db('test'); // 选 择 数据 库 
if (mysql_errno ()>0){ 








echo "<br />2. ".mysql_errno(). mysql error()."«br /»" ; // 检 查 错误 
exit(); 

} 

else{ 





echo "2. test 数据 库 被 选取 ! «br /2"; 





$s-mysql close($link); // 关 闭 与 MySQL 服务 器 的 连接 





if(!$s)( 
echo "<br />3. ".mysql errno().":".mysgl error()."«br /»" ; // 检 查 错误 
exit(); 
n 
else echo "3. 关闭 连接 成 功 ! «br /»"; Á 
运行 结果 〈 若 MySQL 的 主机 ， 用 户 和 密码 是 "localhost"， "日 存在 数据 库 test) 

Deprecated: mysql connect () : The mysql ext isio is deprecated and will be removed 
in the future: use mysqli or PDO instead i NA iampWwwwNextendNch6N6 1 mysql.php on 
line 2 

1， 数据库 连 接 成 功 ! a 

2. test 数据 库 被 选取 ! 


， 关 闭 连接 成 功 ! 
2 行 中 的 mysql. connect 修改 为 @mysql_connect， 1 改 为 "12345"， 运 行 结果 是 


(using password: YES) 





Te 
own database 'testdb' 


1. 数据 库 连 接 成 功 ! 

2. test 数据 库 被 选取 ! 

Notice: Undefined variable: linkl in D:\wamp\www\extend\ch6\6 1 mysql.php 
on line 16 


若 把 第 


Warning: mysql close() expects parameter 1 to be resource, null given in 
D:NwampWwwwNextendNch6N 6 1 mysql.php on line 16 
Sn 


1) 连接 MySQL 数据 库 服 务 器 





(resource mysql connect([ string $server [, string Susername[, string Spassword [, bool 
$new link [, intSclient flags]]]]] ) 

G)resource mysql pconnect ([ string Sserver [. string $username [. string Spassword[. int 
Sclient. flags J]]] ) 

加 打开 或 重复 使 用 一 个 到 MySQL 服务 器 的 连接 . 

加 打开 一 个 到 MySQL 服务 器 的 持久 连接 。 


语法 格式 





函数 功能 











(ON 
PHP 动态 网 页 设计 与 制作 案例 才 各 第 = 版 ) 了 ) 





会 server: MySQL 服务 器 。 

可 以 包括 端口 号 ， 如 "hostname:port"。 若 PHP 指令 mysql.default _host 未 定义 (默认 情 
况 )， 则 默认 值 是 "localhost3306'. 在 SQL 安全 模式 时 ， 用 "localhost:3306'. 
Susername: AP. 

默认 值 由 mysql.default user 定义 . 在 SQL 安全 模式 时 ， 用 服务 器 进程 所 有 者 的 用 户 名 。 
S password: 密码 . 

默认 值 由 mysql.default_password 定义 。 在 SQL 安全 模式 时 ， 用 空 密码 。 
参数 说 明 | new link: 指定 打开 的 新 连接 标识 符 . 

如 果 用 同样 的 参数 第 二 次 调用 mysql. connect(), 将 不 会 建立 新 连接 , 而 将 返回 已 经 打开 
的 连接 标识 。 参 数 new_link 改变 此 行为 并 使 mysql_connect() 总 是 打开 新 的 连接 。 
client flags: MySQL. 客户 端 常量 。 

@@ 可 以 是 以 下 常量 的 组 合 : MYSQL CLIENT SSL, MYSQL CLIENT | COMP RESS, 
MYSQL_CLIENT_IGNORE_SPACE 或 MYSQL. CLIENT INTERA CTIVE. 

Gclient. flags 参数 可 以 是 以 下 常量 的 组 合 : MYSQL CL COMPRESS, MYSQL. 
CLIENT IGNORE. SPACE 或 者 MYSQL. CLIENT INTERA( 
返回 值 @D 若 执行 成 功 ， 则 返回 一 个 整数 值 (MySQL 连接 标识 )% 若 执行 失败 ， 则 返回 FALSE。 

@ 若 执行 成 功 ， 则 返回 一 个 正 的 MySQL 持久 连接 标识 符 ; 若 出 错 ， 则 返回 FALSE. 


Lun 


(D 本 扩展 自 PHP 5.5.0 起 已 废弃 ， 应 使 用 MySQLi 或 PDO_MySQL 扩展 来 替换 。 用 以 替代 本 函数 的 
有 mysqli connect). PDO:: construct().. 

Q) PHP 程序 结束 时 ， 与 服务 器 的 连接 就 被 关闭 ， Habt edd a mysql_close) 关闭 了 . 

© 可 以 在 函数 名 前 加 上 一 个 @ 来 抑制 出 错时 的 错误 信息 

mysql_pconnect() 函 数 与 miysqL_connect() 语 法 相同 ， GU TOLTJUA. 

O 每 次 连接 前 ， 要 答 查 是 否 有 同样 参数 的 连接 ,车 有 ,” 则 直接 使 用 . 

®© 不 能 用 mysqdl fl6s60) 函 数 关闭 它 。 

© 当 脚 本 执行 完毕 后 ， 也 不 会 切断 对 服务 器 的 连接 ， 故 称 为 "永久 性 连接 "。 

图 使 用 持久 连接 需要 调整 Apache 和 MySQL 的 配置 以 使 不 会 超出 MySQL 所 允许 的 连接 数目 。 


2) 选择 数据 库 


语法 格式 | bool mysql select. db ( string $database_name [, resource $ link_ identifier ] ) 
函数 功能 | 选择 MySQL 数据 库 。 
E database name: 选择 的 数据 库 名 称 。 
参数 说 明 link identifier: 可 选 ，MySQL 连接 标识 。 
返回 值 ”| 成 功 时 返回 TRUE， 失败 时 返回 FALSE. 


un 
如 不 指定 连接 标识 ， 则 使 用 由 mysql_connect) 最 近 打 开 的 连接 。 如 果 没有 找到 指定 连接 , 会 尝试 不 带 参 
数 调用 mysql_connect) 来 创建 。 如 没有 找到 连接 或 无 法 建立 连接 ， 则 会 生成 E_WARNING 级 别 的 错误 。 

3) 检查 错误 




















语法 格式 © int mysql. errno ([ resource $link_identifier ] ) 


22) 0 


(8) string mysql_error ([ resource Slink identifier ] ) 


es 
6 MEE 


函数 功能 Dkm E—4- MySQL 函数 的 错误 号 码 ， 如 果 没 有 出 错 ， 则 返回 0( 零 )。 
回 返回 上 一 个 MySQL 函数 的 错误 文本 ， 如 果 没 有 出 错 ， 则 返回 "( 空 字符 串 ) 
参数 说 明 link identifier: 由 mysql_connect() 返回 的 连接 标识 。 


(D) 如 果 指 定 了 可 选 参数 则 用 给 定 的 连接 提取 错误 代码 。 否则 使 用 上 一 个 打开 的 连接 。 
© 如 果 没 有 指定 连接 标识 ， 则 使 用 上 一 个 成 功 打开 的 连接 从 MySQL 服务 器 提取 错误 信息 。 

















错误 报告 的 处 理 
PHP 的 错误 报告 通过 函数 实现 ， 格 式 如 下 ， 其 中 参数 的 含义 如 表 6.18 PET. 


int error reporting([int level]) twm 
5$ — 


3& 6.18 error. reporting() level 参数 取 值 
N 


SER. WARNING. 
A 





9 ,/\>— 2. 
Lun 人 | AEN 
© NN 何 消息 ; level=E_ALL; 报告 所 有 消息 。 
© 程序 调试 阶段 需要 报告 错误 和 警告 ， 以 帮助 识别 和 查 明 问 题 。 
© 用 户 使 用 阶段 ， 应 该 禁止 错误 和 警告 消息 的 出 现 ， 以 免 造 成 困惑 。 
图 在 函数 前 的 @ 也 能 屏蔽 函数 的 错误 报告 ， 
4) 关闭 数据 库 连接 
语法 格式 | bool mysql close ([ resource Slink_identifier = NULL ] 
函数 功能 | 关闭 指定 的 连接 标识 所 关联 的 到 MySQL 服务 器 的 非 持 久 连 接 。 
参数 说 明 | link identifier MySQL 的 连接 标识 。 
返回 值 | 成 功 时 返回 TRUE， 失 败 时 返回 FALSE. 


(D 如 果 参 数 为 NULL, 将 使 用 最 近 一 次 mysql_connect() 建 立 的 连接 ; 如 果 没 有 找到 可 使 用 的 连接 , 将 


产生 一 个 E_WARNING £k. 
9 
= 

















© 当 程 序 终止 时 ， 会 自动 关闭 mysql_connect() 函 数 打 开 的 连接 。 
© 不 会 关闭 由 mysql_pconnect() 建立 的 持久 连接 。 
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2. MySQLi 扩展 





展 ( 而 向 过 程 ) 


<?php 
$link-mysqli connect("localhost","root","","");  // 连 接 MySQL 服务 器 


if (mysqli_connect_errno(S$1ink)>0)1{ 


echo "<br /»1. ".mysqli connect errno($link).":".mysqli connect error 
($link) ."<br /»" ; // 检 查 错误 
exit(); 
} 
else( 


echo "1. 数据 库 连 接 成 功 ! «br />"; 
mysqli select db($link,'testdb'); /7 选择 数据 库 ， 
if(mysqli errno(Slink)»0)( 2 
echo "<br /»2. ".mysqli errno ($link). goce error($link)."«br 
/»" ; // 检 查 错 误 X 


exit (); E 


) 





else{ AX \ 
echo "2. test 数据 库 被 选取 ! SR /»"; 
mysqli close($link); j MySQL 服务 器 的 连接 


if (mysqli errno($ 
echo SS NA [om errno(). Simoni error ($link) . "<br 
/>"”; // 检 查 错误 RAA X LK 


PCS r 4H 
) JA > NS 








y 的 主机 ， 用 户 和 
1， 数 据 库 连接 成 功 ! 
2. test 数据 库 被 选取 ! 
关闭 连接 成 功 ! 









Warning: mysqli connect(): (HY000/1049): Unknown database '123456' in 
D:NwampWwwwNextendNch6N 6 1 mysqli.php on line 2 
1. 1049:Unknown database '123456"' 





J 
1. 数据 库 连 接 成 功 ! 
2. 1049:Unknown database 'testdb' 





1. 数据 库 连接 成 功 ! 
2. test 数据 库 被 选取 ! 
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Notice: Undefined variable: linkl in D:\wamp\www\extend\ch6\6 1 mysqli.php 
on line 16 

Warning: mysqli close() expects parameter 1 to be mysqli, null given in 
D:NwampWwwNextendVch6N 6 1 mysqli.php on line 16 

3.05 





6 1 mysglio.php 


«?php 
$mysqli = new mysqli("localhost", "root", "", "test"); // 连 接 MySQL 服务 器 
if(S$mysqli-»connect errno»0)( 


echo "<br /»1. ".S$mysgli-»connect errno.":".$mysqgli-»connect error."«br 
/»" ; // 检 查 错误 
exit(); z 


E ,人 


echo "1. 数据库 连 接 成 功 ! <br />"; RN 





$mysqli- -»select . db('test'); // 选 择 数 


7 


if ($mysqli-»errno»0)( XY 
echo "«br /»2. lage ^ ncm /»" ; // 检 查 错误 





exit(0; 
| KO 


else{ 
echo "2. test c aiiis «br />n7 13 
$s- socie aU. 4 连接 


if(!$s) 
.echo . <br /»".$mysq. Xo. ":".$mysgli-»error. 
KR DR /»" ; // 


NO AZ 


diss echo "3. 关闭 连接 成 功 ! «br /»"; 























若 MySQL 的 主机 ， 用 户 和 
I] 6_1_mysqli.php 


1) 连接 MySQL 数据 库 服 务 器 





(D) mysqli mysqli_connect ([ string Shost = ini_get("mysqli.default_ host") 

[, string $username -ini. get ("mysgli. default. user") 

[, string Spasswd = ini. get("mysgli.default pw") 

[ string Sdbname ="" 

[, int$port = ini get("mysgli.default. port") 

[. string Ssocket = ini. get("mysgli.default socket") ]]]]]] ) 
(2) mysgli:: construct ([ string $host = ini. get("mysgli.default | host") 

[. string Susername = ini, get("mysgli.default. user"). 


语法 格式 
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[ string $passwd = ini_get("mysqli.default_ pw") 

[, string Sdbname = "" 

L intSport = ini_get("mysqli.default_port") 

[ string $socket = ini_get("mysqli.default_ socket") ]]]]]] ) 





函数 功能 | 打开 一 个 到 MySQL 服务 器 的 连接 。 





host: Tit. 规定 主机 名 或 IP Mun. 
username; 可 选 。 规 定 MySQL 的 用 户 名 。 
passwd: 可 选 。 规 定 MySQL 的 密码 。 











参数 说 明 | dbname: 可 选 ,规定 默认 使 用 的 数据 库 名 称 。 

port: 可 选 。 规 定 尝试 连接 到 MySQL 服务 器 的 端口 号 。 

socket: 可 选 。 规定 socket 或 要 使 用 的 已 命名 pipe. i 
返回 值 人 @D 如 果 成 功 ， 则 返回 一 个 代表 到 MySQL 服务 器 的 连接 标识 ; 如果 出 错 ， 则 返回 FALSE. 





回 如 果 成 功 ， 则 返回 一 个 代表 到 MySQL MEL 则 返回 FALSE. 


S un QN 


mysqli. connect() 4&5; mysql. connect() 4k ey 的 连接 ， 但 从 语法 上 看 有 以 下 区 别 。 
(D 返回 值 不 同 。mysqli_connect() 返 回 的 是 一 个 对 

®© 参数 不 同 。mysqli_ en EN 

图 mysqli:: construct () 是 mysqli A re 自动 执行 。 详 见 下 面 的 示例 6-1-3. 


2) 选择 数据 库 NS 





语法 格式 [ET i $link , TE 





bool mysgli::select x (string Sdbname ) X. 





函数 功能 “| 选择 用 于 数据 库 查询 的 默认 数据 库 . Pu 
dbname: 选择 的 数据 库 名 称 ， 。，。 NV 








参数 说 明 ink: 由 mysgli. connect() xmi H 
返回 值 功 时 返回 TRUE， 失 败 时 返回 FALSE. 





S un 


应 该 只 被 用 在 改变 本 次 连接 的 数据 库 ， 也 能 在 mysqli_connect() 第 四 个 参数 确认 默认 数据 库 .mysqli:: 
select_db() 是 mysqli 类 的 方法 (函数 )。 使 用 方法 见 下 面 的 示例 6-1-3 第 2 行 。 





3) 检查 错误 
© int mysgli. errno(mysgli $link); int $mysgli-^errno; 
(2) string mysgli. error (mysqli $link ); string $mysgli-»error; 
语法 格式 | © int mysqli. connect. errno ( void ); int $mysgli-»connect. errno; 
@ string mysqli connect error (void ); string $mysgli-»connect. error; 
© array mysgli. error. list ( mysqli $link ); array Smysgli-error list; 





@D@ 返 回 最 近 的 函数 调用 产生 的 错误 代码 。 
函数 功能 | @@@ 返 回 最 近 的 函数 调用 产生 的 错误 代码 。 
回 返回 最 近 调用 函数 的 错误 列表 。 








参数 说 明 |link: 由 mysqli connect() 返回 的 连接 标识 。 
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@D 返 回 最 近 的 mysqli 函数 调用 产生 的 错误 代码 ， 返 回 0 代表 没有 错误 发 生 。 

加 返回 最 近 的 mysqli 函数 调用 产生 的 错误 文本 ， 如 果 没 有 出 错 ， 则 返回 " ( 空 字符 囊 )。 

图 返回 最 近 的 mysqli_connect( 函数 调用 产生 的 错误 代码 ， 返 回 0 代表 没有 错误 发 生 。 
返回 值 | @@ 返 回 最 近 的 mysqli_connect() 函数 调用 产生 的 错误 文本 ， 如 果 没 有 出 错 ， 则 返回 "( 空 字 

符 囊 ). 

回 返 回 最 近 调用 函数 的 错误 列表 ， 每 个 错误 都 是 一 个 带 有 ermo( 错 误 代码 )、error( 错 误 文 

本 ) 和 sqlstate 的 关联 数组 。 






S un 

客户 端 错误 在 Mysqlerrmsg.h 头 文件 中 列 出 , 服务 端 错误 号 在 mysqld errorh P 51 i. 在 mysql 源码 分 
发 包 中 的 Docs/mysqld_errortxt 可 以 发 现 一 个 完整 的 错误 消息 和 错误 号 . 

4) 关闭 与 MySQL 服务 器 的 连接 IZ 


语法 格式 “| bool mysqli close ( mysqli $link ) bool mysqli: :close (void). E 
函数 功能 | 关闭 先前 打开 的 数据 库 连 接 。 5 
参数 说 明 | link: 由 mysqli. connect() 返回 的 连接 标识 人 A NF 

返回 值 | 成 功 时 返回 TRUE， 失 败 时 返回 FALSE O 一 


SÉ un K Wa * 

mysgli:: close) Æ mysqli A 66i (dile). S ZA 
663 WERFEN 000 
管理 数据 库 首先 要 创建 数据 库 ， 这 只 是 一 










示例 6-2 “创建 数 





示例 6-2 ”创建 数据 表 message 

































name varchar(20) 
email varchar(40) 
password | varchar(12) 
id | auto increment 
插入 如 下 数据 : 
示例 6-2 ”向 数据 表 message 添加 下 列 数据 (INSERT 操作 ) 
name E-mail password id 
张 三 | szhang123@ces.edu.cn 123456 (自动 增加 ) 
ES | Slil23@Cs.edu.cn 000000 (自动 增加 ) 








收据 表 message (UPDATE, DELETE 操作 ) 











示例 6-2 
张 三 szhang123@cs.edu.cn asdfg 更 新 密码 
李 四 | Sli123@Cs.edu.cn 000000 删除 
1. MySQL 扩展 


可 以 利用 MySQL 扩展 中 的 函数 创建 数据 库 mysql. create db ()， 也 可 以 使 用 SQL 语句 
先 编写 相应 的 SQL 命令 ， 再 把 SQL 命令 传送 给 mysql_query0 来 创建 数据 库 表 ， 插 入 和 更 


新 数据 。 


6_2_mysql.php//MySQL jj 


<?php ó 
$link-8mysql connect ("localhost","root",""); QE — 服务 器 








771 创建 新 数据 库 NN 
//mysql create db("bank",$1link); // 使 用 的 ie 4.x 以 上 版 本 ， 该 函数 不 可 用 
$sql -"create database bank" ; // 编 写 

d Ti 语句 


mysql query($sql) ; 
if(!mysql select db("bank"))( 


echo "«br /»1:bank 数据 库 AS 
NS 





exit(); 、 
} 

else echo "<br ART: =: > 经 创建 ";? y X 
x 


//2 创建 数据 表 pay 
ssage ('id' ANC T NULL AUTO INCREMENT COMMENT 





$SQL-"CREATE TABLI] 
HEDE, ZA 
N 'name' VARCHAR 20) NULL COMMENT ' 用 户 名 ' , 


NO i B 
N 'email' VARCHAR (40) NULL COMMENT ' 用 户 电 子 邮 箱 '， 
'password' VARCHAR(20) NULL COMMENT ' 用 户 密码 ' , 


PRIMARY KEY ('id')) ENGINE = InnoDB CHARSET-utf8 COLLATE 
" 


utf8 bin; "; 
mysql query($SQL); // 执 行 SOL 语句 





if (mysql_errno()){ 
echo "<br />2:".mysql_errno( ).":".mysql error( )."<br /»"; // 检 查 错误 
exit (); 
) 
else echo "«br />2: 在 bank 数据 库 中 已 经 创建 数据 表 bmessage"; 
//3 插入 数据 
$SQL-"INSERT INTO bmessage (name, email, password) VALUE ('9K—', 'szhang1238 


126.net', '123456');"; 
mysql query($SQL); // 连 接 数据 库 并 执行 SOL 命令 


$SQL-"INSERT INTO bmessage (name, email, password) VALUE (' 李 四 ','slil23@ 








126.net', '000000')"; 


mysql query($SQL); // 连 接 数据 库 并 执行 SOL 命令 














o 第 6 章 网 上 社区 设计 与 PHP 数据 库 访问 


© =O OOS 


if(mysql errno()) echo "<br />3:".mysql_errno().":".mysql_error( )."«br 
/>"; // 检 查 错 误 
if(mysql affected rows()!=1){ // 检 查 数据 是 否 添 加 入 表 
echo "<br />3: 添 加 数据 没有 成 功 "; 


exit() 7 





) 


else( 
$id-mysgl insert id(); // 自 动 为 主键 分 配 值 
echo "<br />3: 添 加 数据 成 功 , 记录 序号 为 " . Sid; 
} 
1/4 更 新 数据 
$SQL="UPDATE bmessage SET password-'asdfgh' WHERE name=' 张 三 '; "; 





mysql query($SQL); // 执 行 SOL 命令 
if (mysql_affected_rows () !=1) { // 检 查 数据 是 否 执行 os 
echo "<br />4: 更 新 数据 没有 成 功 "7 


exit(); 


) "S 
else echo "<br />4: 更 新 数据 成 功 "; S S 
S) 


//5 更 新 数据 E 


S$SQL-"DELETE FROM bmessage WHE! ; 
mysql query($SQL); Vi 接 数据 库 并 执行 SQL 命令 
if(mysql affected rows ()! COMI BERE E 
ho “<br /»5: ar 7 
Be E A xs 
) iN E. ad 
else echo Iia 数据 成 功 "; X 


776 删除 数据 库 “< 一 cr 
y Pp 3 
$sql-"D NS ASE bank"; / EGRE 
if (mysql ect db("bank"))( 
if (mysql_query ($sql)) echo "6:book 数据 库 已 经 被 删除 "; 
else ( 


echo "6:book 数据 库 没有 被 删除 "; 


exit(); 





) 
) 
mysql close(); 
7> 














运行 结果 47 MySQL 的 主机 ， 用 户 和 密码 是 "localhost"."root","" 
1:bank 数据 库 已 经 创建 
2: 在 bank 数据 库 中 已 经 创建 数据 表 bmessage 
3 :添加 数据 成 功 , 记录 序号 为 2 
4 :更 新 数据 成 功 
5 :删除 数据 成 功 
6:book 数据 库 已 经 被 删除 
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1) 创建 MySQL 数据 库 
语法 格式 | bool mysql create db ( string Sdatabase name [, resource $link_ identifier ] ) 
函数 功能 | 尝试 在 指定 的 连接 标识 所 关联 的 服务 器 上 建立 一 个 新 数据 库 。 
参数 说 明 abe nies 在 指定 连接 标识 的 服务 器 上 建立 一 个 新 数据 库 。 
| link identifier: 指定 MySQL 连接 标识 - 
返回 值 | 成 功 时 返回 TRUE， 失 败 时 返回 FALSE. 























S un 


QD) 如 不 指定 ink identifier. NJA & mysql. connect) 最 近 打开 的 连接 。 如 果 没有 找到 该 连接 ， 
试 不 带 参 数 调用 mysql_connect() 来 创建 。 如 没有 找到 连接 或 无 法 建立 连接 ， 则 会 生成 E_ WARNING bi 
的 错误 。 
回 如 果 MySQL 扩展 是 基于 MySQL 4.x 客户 端 库 编译 的 话 ， 则 pisan 。 不 提倡 使 用 函 
žk mysql_create_db()， 最 好 用 mysql_query() 来 提交 一 条 SQL 命令 : QN 

$sql -"create database" .$database; 

mysql query($sql) ; ZA 

© A PHP5.5.0 A GÀ, AERAR, oem 或 PDO_MySQL 扩展 来 将 其 痊 换 、 
用 以 替代 本 函数 的 有 mysqli_query()，PDO: jr oa 


2) 执行 SQL 语句 V 


语法 格式 (1) resource mysql. qi rine resource pem NULL ]) 


(2) resource AS string Sdatabase , si [, resource $ link. identifier ] ) 

向 与 指定 思 接 的 服务 器 中 的 当前 活动 据 库 发 送 一 条 查询 (不 支持 多 条 查询 )。 

Dt A c 库 并 在 其 上 执行 查询 。 

database: 操作 的 数据 库 。 dm Di 

参数 说 明 pes i2 SQL iig. dei 不 以 分 号 结束 ， 被 嵌入 的 数据 应 该 正确 地 转 义 。 
entifier: 指定 MySQL 连接 标识 。 

对 SELECT、SHOW、DESCRIBE、EXPLAIN 等 SQL 语句 ， 成 功 时 返回 一 个 resource; 

返回 值 | 对 INSERT、UPDATE、DELETE、DROP 等 SQL 语句 ， 成 功 时 返回 TRUE; 

出 错时 返回 FALSE; 如 果 没有 权限 访问 查询 语句 中 引用 的 表 ， 返 回 FALSE. 














函数 功能 
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(D 函数 如 果 没 有 提供 可 选 的 连接 标识 ， 会 去 找 一 个 到 MySQL 服务 器 的 已 打开 的 连接 ; 如 果 找 不 到 
已 打开 连接 ， 则 会 尝试 无 参数 调用 mysql. connect() 来 建立 一 个 。 

© 返回 的 结果 资源 应 该 传递 给 mysql. fetch. array() 和 其 他 函数 来 处 理 结果 表 ,取出 返回 的 数据 ,假定 查 
询 成 功 ， 可 以 调用 mysql_num_rows() 来 查看 对 应 于 SELECT 语句 返回 了 多 少 行 , 或 者 调用 mysql affected 
rows) 来 查看 对 应 于 DELETE. INSERT. REPLACE 或 UPDATE 语句 影响 到 了 多 少 行 . 

图 两 函数 的 区 别 在 于 : 后 者 可 以 不 使 用 函数 mysql_select_db() 选 择 数 据 库 ， 而 在 执行 SQL 语句 的 同 
时 ， 选 择 数据 库 。 

(4) 自 PHP 4.0.6 起 不 提倡 使 用 mysql_db_query()， 用 mysql_select_db(), mysql_query()- 

© 自 PHP 5.5.0 起 已 废弃 ， 并 在 将 来 会 被 移 除 。 应 使 用 MySQLi 或 PDO_MySQL 扩展 来 替换 。 用 以 
替代 本 函数 的 有 mysqli_query0，PDO::query0. 
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( ) = TSN 
3) 分 配 主键 的 值 


语法 格式 | intmysql insert id ([ resource Slink identifier ] ) 

返回 给 定 的 link_identifier 中 上 一 步 INSERT 查询 中 产生 的 AUTO INCRE MENT 的 ID 
函数 功能 | 号 ， 如 果 没有 指定 link_identifier， 则 使 用 上 一 个 打开 的 连接 。 
参数 说 明 | link identifier: 指定 MySQL 连接 标识 - 


un 


O 如 果 上 一 查询 没有 产生 AUTO INCREMENT 的 值 ， 则 mysql_insert_id0 返 回 0. 

Q) 如 果 需 要 保存 该 值 以 后 使 用 ， 就 要 确保 在 产生 了 值 的 查询 之 后 立即 调用 mysql_insert_id0)。 

图 如 果 AUTO INCREMENT 的 列 的 类 型 是 BIGINT， 则 mysql_insert_id() 返回 的 值 将 不 正确 。 可 以 
在 SQL 查询 中 用 MySQL 内 部 的 SQL 函数 last_insert_id() 来 替代 。 

图 函数 last_insert_id0) 将 MySQL 赋予 的 值 返回 一 个 AUTO | INCREMENTS 志 的 字段 ,不 管 字段 的 类 
型 如 何 ， 只 涉及 INSERT 操作 . S 


4) 返回 最 近 受 影响 的 记录 数 


语法 格式 | int mysql affected. rows ([ resource Slink i m L]) 
取得 最 近 一 次 与 link_identifier 关联 (T. UPDATE 或 DELETE 查询 所 影响 的 记 
































函数 功能 Ri. KY 

参数 说 明 | link identifier: 448 TE 
如 果 执 行 成 功 ， 则 返回 THRA; 如 果 最 近 一 次 查询 失败 ， 则 函数 返回 -1, 
当 计算 UPDATE 实际 更改 | 旧 列 和 新 列 值 相 了 不 再 受 影响 行 的 计数 中 。 


没有 WHERE 子 悦 的 人 ARENO, REMAT Sri. 
返回 什 "INSERT .. NE LICATE KEY UPDATE" dorus a, 当 执 行 了 一 次 INSERT 返 
回 的 值 会 是 1 eee io 一 次 UPDATE 将 返回 2。 
如 果 最 近 二 次 操作 是 没有 任何 条 件 ) 的 DELETE 查询 ， 在 表 中 所 有 的 记录 都 会 被 
, AAA mik REPLACE 语句 首先 删除 具有 相同 主键 的 记录 ， 然 后 插入 一 个 新 记录 。 本 
回 的 是 被 删除 的 记录 数 加 上 被 插入 的 记录 数 . 








CET 
É PHP 5.5.0 起 已 废弃 ， 并 在 将 来 会 被 移 除 。 应 使 用 MySQLi A PDO MySQL 扩展 来 替换 。 用 以 替 
代 本 函数 的 有 mysqli_affected_rows(), PDOStatement::rowCount()。 


5) 删除 数据 库 


语法 格式 bool mysql. drop. db ( string Sdatabase name [, resource $ link_ identifier ] ) 
函数 功能 | 尝试 丢弃 (删除 ) 指定 连接 标识 所 关联 的 服务 器 上 的 一 整个 数据 库 。 


参数 说 明 database name; 在 指定 连接 标识 的 服务 器 上 建立 一 个 新 数据 库 。 成功 时 返回 TRUE. 
link identifier: 指定 MySQL 连接 标识 - 
返回 值 “| 成 功 时 返回 TRUE， 或 者 在 失败 时 返回 FALSE. 


(D 如 果 MySQL 扩展 库 是 基于 MySQL 4x 客户 端 库 建立 的 ， 则 本 函数 不 可 用 。 
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prp GE Sepa eno 人 了 


和 


回 不 提倡 使 用 mysql_drop_db() 函数 . 最 好 用 mysql_query() 提交 一 条 SQL DROP DATABASE 语句 来 
ABA. 

© & PHP 5.5.0 3& GR Je, JE e ERR OSEE. 应 使 用 MySQLi 或 PDO MySQL 扩展 来 替换 。 用 以 
替代 本 函数 的 有 Execute a DROP DATABASE query. 








2. MySQLi 扩展 
«?php 
$mysgli-mysqli connect ("localhost","root","",""); // 连 接 MySQLi 服务 器 
/ /1 创建 新 数据 库 
$sql -"create database bank" ; // 编 写 SOL 语句 
mysqli_query ($mysqli, $sql) ; / /执行 SOL 语句 
if(!mysqli select db($mysqli,"bank"))( 入 
echo "<br />1:bank 数据 库 没有 创建 "; a K 


exit( ); QN 


1 


//2 创建 数据 表 
$SQL="CREATE TABLE bmessage('id' INT(10) vicam, INCREMENT COMMENT ' 用 户 id 号 ' ， 
'name' Voca NULL COMMENT ' 用 户 名 ' , 





'emai (40) NULL COMMENT ' 用 户 电子 邮箱 '， 
VARCHAR(20) NULL COMMENT “用 户 密码 ， 
('id')) ENGINE = CHARSET-utf8 COLLATE utf8 bin; "; 
mysqli query ($mysqli, // 执 行 SOL ili 
if (mysqli_errno m MA 
echo "<br />2 sqli_errno ($my. ":;".mysqli error($mysqli)."«br 
> // 检 查 错 误 全 X 
exit 9e 
y YA 
A AS "<br />2: 在 bank 数据 库 中 已 经 创建 数据 表 bmessage"; 
//3 插入 数据 
$SQL-"INSERT INTO bmessage (name, email, password) VALUE ('3K—','szhangl230 
126.net', '123456');"; 
mysgli query ($mysqli,$SQL); // 连 接 数据 库 并 执行 SOL 命令 
$SQL="INSERT INTO bmessage (name, email, password) VALUE (' 李 四 ', 'slil23@126. 
net', '000000')"; 
mysqli query ($mysqli, $SQL); // 连 接 数据 库 并 执行 SQL 命令 
if(mysgli errno($mysqli)) echo "<br /»3:".mysqli errno($mysqli).":".mysgli 
error ($mysgli)."«br /»"; // 检 查 错误 
if (mysqli affected rows (Smysqli) !=1){ // 检 查 数据 是 否 添加 入 表 
echo "<br />3: 添 加 数据 没有 成 功 "; 


exit (); 





else( 


$id-mysqli insert id($mysqli); // 自 动 为 主键 分 配 值 
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echo "<br />3: 添 加 数据 成 功 , 记录 序号 为 " .$id; 





//4 更 新 数据 
$SOL-"UPDATE bmessage SET password-'asdfgh' WHERE name=' 张 三 '; "7 
mysqli query ($mysqli,$SQL); // 执 行 SQL 命令 
if (mysqli affected rows ($mysqli) !=1) { // 检 查 数据 是 否 执行 更 新 
echo "<br />4: 更 新 数据 没有 成 功 "; 
exit(); 


) 

else echo "<br />4: 更 新 数据 成 功 "; 

//5 更 新 数据 

$SQL="DELETE FROM bmessage WHERE id- 2"; 


mysqli query ($mysqli,$SQL); den Mel SQL 命令 
if(mysqli affected rows ($mysqli)!-1)( 作成 
echo "<br />5: 删 除数 据 没有 成 功 "; K 


exit (); 





) AS 
else echo "<br />5: 删 除数 据 成 功 "; S 


/716 删除 数据 库 
$sql-"DROP DATABASE bank"; 
if(mysqli select iue )t 
if(mysqli | quer nsu sd echo VA 数据 库 已 经 被 删除 "7 
else { 


echo "<br Ië: ATA Se x d 


exito; X 
) > S | ; x^ 


X 


// 连 接 数 据 库 








} NN 
NR ($mysqli); 23 
?» 





了 结果 4 MySQL 的 主机 ， 用 
同 6_6_mysql.php 








全 6 2 mysglio.php//M. 








<3ph 
PE = new mysqli ("localhost", "root", "", ""); // 连 接 MySQLi 服务 器 
$mysqli->query ("set names 'utf8'"); // 设 置 客户 端的 字符 集 
//1 创建 新 数据 库 
$sql -"create database bank" ; // 编 写 SOL 语句 
$mysqli-»query($sql) ; // 执 行 SQL 语句 


if (!$mysqli->select_db ("bank") ) { 
echo "<br /»1:bank 数据 库 没有 创建 "; 
exit(); 

) 

else echo "<br /»1:bank 数据 库 已 经 创建 "; 
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//2 创建 数据 表 
$SQL-"CREATE TABLE bmessage ('id' INT(10) NOT NULL AUTO INCREMENT COMMENT 
"用 户 ID 号 "， 
'name' VARCHAR(20) NULL COMMENT ' 用 户 名 ' ， 
'email' VARCHAR(40) NULL COMMENT ' 用 户 电子 邮箱 '， 
'password' VARCHAR(20) NULL COMMENT ' 用 户 密码 ' , 
PRIMARY KEY ('id')) ENGINE = InnoDB CHARSET-utf8 
COLLATE utf8 bin; "; 
$mysqli-»query($SQL); / [AAT SOL 语句 
if ($mysqli-»errno)( 
echo "<br /»2:".$mysqli-»errno.";".$mysgli-»error."«br /»";  // 检 查 错误 
exit(); 
) 





else echo "<br />2: 在 bank 数据 库 中 已 经 创建 数据 表 bmess 
/73 插入 数据 CNN 
$SQL-"INSERT INTO bmessage (name, email, p: seis VALUE (' 张 三 ', 'szhang123 
@126.net', '123456');"; / iV 
$mysqli-»query ($SQL); A ka 库 并 执行 SQL 命令 
$SQL="INSERT INTO bmessage (name, ail, password) VALUE (' 李 四 ','sli123 
8126.net', '000000')"; E i 
$mysqli->query ($SQL) ; N // 连 接 数据 库 并 执行 SQL 命令 
if($mysqli-»errno) echo ein, Us. S ":".$mysqli-»error."«br 
/>"; [yiii ,Vv » 
if($mysqli-»affected rows!-1)( // dii nh 
echo "<br /»3:3 Jm db RI"; r 
d 








exit (); ^ X 
) P x S 
else( AN j 
$id-$mysqli-»insert id; // 自 动 为 主键 分 配 值 
echo "<br />3 :添加 数据 成 功 , 记录 序号 为 " .$id; 
//4 更 新 数据 
$SQL-"UPDATE bmessage SET password-'asdfgh' WHERE name-' un 
$mysqli-»query ($SQL); // 执 行 SQL 命令 


if ($mysqli->affected rows!-1)( // 检 查 数 据 是 否 执 行 更 新 
echo "<br />4: 更 新 数据 没有 成 功 "; 
echo "<br />4: 更 新 数据 没有 成 功 "; 
exit(); 
) 
else echo "<br />4: 更 新 数据 成 功 "; 


/15 更 新 数据 
SSQL="DELETE FROM bmessage WHERE id= 2"; 
$nysqli-»query ($8QL); // 连 接 数据 库 并 执行 SOL 命令 





if($mysqli-»affected rows!-1)( // 检 查 是 否 操作 成 功 
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echo "<br />5: 删 除数 据 没有 成 功 "; 
exit(); 
) 
else echo "<br />5 :删除 数据 成 功 "; 
//6 删除 数据 库 
$sql-"DROP DATABASE bank";// 连 接 数 据 库 
if ($mysqli->select db("bank"))( 
if($mysqli-»query($sql)) echo "<br />6:book 数据 库 已 经 被 删除 "; 


























else ( 
echo "<br /»6:book 数据 库 没有 被 删除 "; 
exit(; 
} 
$nysqli-»close(); £L Io 
2» 4 
运行 结果 ” 若 MySQL 的 主机 ， 用 户 和 密码 是 "localhost","root","" 
F 6.2. mysql.php A) 
NS 
1) 执行 SQL 语句 E ! 
语法 格式 mixed mysqli::query ( string $ int Reales cin Meu OE RESULT]) 
mixed mysgli. query ( ig $query [, int $result mode = MYSQLI STORE. RESULT ] ) 
函数 功能 "RIA A SQ, ; 





link: (o ER d m. 有 connect() BE c 
query: 规定 SQL 语句 的 字符 串 。 m 
参数 说 明 | resultmode: del 可 以 是 下 列 常量 中 
ie se ESULT ( 如果 ' e 数据 ， 请 使 用 这 个 )。 
QLU: 'ORE RESULT ( XX: 
4E 的 SELECT. SHOW. mue 3 EXPLAIN 查询 ,将 返回 一 个 mysqli_result 对 
Ri 针对 其 他 成 功 的 查询 ， 将 返回 TRUE. 如果 失败 ， 则 返回 FALSE. 





返回 值 








Uk yg 
2) MySQLi 扩展 中 其 他 执行 SQL 语句 函数 


CDbool mysqli_multi_query (mysqli Slink, string $query); 
CDbool mysqli::multi_query (string Squery); 
@)bool mysqli_real_query (mysqli $link, string $query); 
(2)bool mysqli::real_query (string $query); 
@@D 执 行 一 个 或 多 个 针对 数据 库 的 查询 。 多 个 查询 用 分 号 进行 分 隔 。 
回执 行 一 个 单条 数据 库 查 询 。 
link: (面向 过 程 ) 由 mysgli connect() 返回 的 连接 标识 。 
参数 说 明 | query: GD 规定 一 个 或 多 个 查询 ， 用 分 号 进行 分 隔 。 

加 查询 字符 串 。 查 询 中 的 数据 可 以 进行 属性 转 义 。 
@@ 如 果 第 一 个 查询 失败 ， 则 返回 FALSE. 
加 成功 时 返回 TRUE， 或 者 失败 时 返回 FALSE. 





语法 格式 





函数 功能 








返回 值 
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(D. multi_query() 从 第 一 个 查询 可 以 使 用 mysgli use result()&& mysgli store result()4 k RK. 所 有 后 
续 的 查询 结果 可 以 用 mysqli more results()f» mysqli_next_result() 处 理 。 

© real_query() 的 结果 可 以 使 用 mysqli_store_result() 或 mysqli_use_result() 检 索 或 存储 。 为 了 确定 给 定 
的 查询 是 否 真 的 返回 一 个 结果 集 , 可 以 查看 mysqli_field_count(). 








© bool mysqli_next_result (mysqli $link ) 

bool mysqli::next_result ( void ) 
(2) bool mysqli_more_results ( mysqli $link ) 

bool mysgli::more. results ( void ) 
语法 格式 | G)mysqli result mysgli::store. result ([ int Soption ] ) 

(S) mysgli result mysgli store result ( mysqli Slink [, int Soption]) ;一 

(4) mysgli. result mysgli. use. result ( mysqli $link ); mysii enit jus emt void 
© int mysgli. field count ( mysqli Slink ); C NN 

int Smysgli-»field count; AS 
(0) mysqli multi query() 准备 下 一 个 结果 集 AN 
回 检查 一 个 多 查询 是 否 有 更 多 的 结果 。 RNs 
函数 功能 | 国 传输 最 后 一 个 查询 的 结果 集 。 -~ he 
GA E). mysqli real query() Jp B did ilb (eH Ree. 
加 返回 最 近 查 询 的 列 数 ， SS- 
link: (面向 过 程 ) 由 my iD 返回 的 连接 标识 2 
参数 说 明 | option: 可 取 值 MOM RE. RESULT. COPY. Datenrate 
Eie A NA 
DARRI 则 返回 TRUE; wR kK, 则 返回 FALSE. 
返回 值 | @@ 返 加 二 个 缓冲 的 结果 对 象 ， 如 果 发 生 错 误 ， 则 返回 FALSE. 

加 一 个 表示 结果 集合 中 的 字段 数 的 整数 . 


di ~ | 


(D multi_query() 从 第 一 个 查询 可 以 使 用 mysqli_use_result() 或 mysqli_store_result() 检 索 结果 集 。 所 有 后 
续 的 查询 结果 可 以 用 mysqli_more_results() 和 mysqli_next_result() 处 理 。 

© real_query0) 的 结果 可 以 使 用 mysqli_store_result() 或 mysqli_use_result() 检 索 或 存储 。 为 了 确定 给 定 
的 查询 是 否 真 的 返回 一 个 结果 集 , 可 以 查看 mysqli_field_count(). 

®© 虽然 使 用 mysqli_free_result0 〇 函数 释放 被 查询 集 占据 的 内 存 一 直 是 很 好 的 做 法 , 但 当 传输 大 规模 的 
结果 集 ， 使 用 mysqli_store_result(0) 就 显得 尤为 重要 。 

图 由 于 use_result0 函 数 不 传 递 来 自 数据 库 的 完整 的 结果 集 ， 因 此 不 能 使 用 如 mysqli_data_seek() 移 动 
到 设 定 的 行 这 样 的 功能 。 要 使 用 此 功能 ， 结 果 集 必须 存储 mysqli_store_result0)。 如 果 进 行 客户 端的 很 多 处 
理 就 不 要 使 用 mysqli_use_result()， 因 为 这 会 占用 服务 器 和 防止 其 他 线程 更 新 任何 表 中 获取 的 数据 。 

© field count 能 被 用 在 用 mysqli_store_result(0) 函 数 确定 查询 是 否 产生 一 个 非 空 的 结果 集 还 是 未 知 的 























查询 属性 。 
3) 分 配 主键 的 值 
mixed mysqli_insert_ id ( mysqli $link ) ; 
语法 格式 MT liinsert id: 








9, 
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函数 功能 返回 给 定 的 link 中 上 一 步 INSERT 查询 中 产生 的 AUTO_INCREMENT 的 ID 号 . 如 果 
没有 指定 link， 则 使 用 上 一 个 打开 的 连接 。 

参数 说 明 | link: 指定 MySQL 连接 标识 。 

返回 值 “| 一 个 表示 产生 ID 的 正 整 数 . 0 表示 更 新 或 没有 AUTO INCREMENT 字段 。 


S un 
如 果 数 字 大 于 最 大 整数 值 ， 它 就 返回 一 个 字符 囊 。 
执行 插入 或 更 新 使 用 last_insert_id() 函 数 声明 也 将 修改 mysqli_insert_id0) 函 数 返回 值 。 
4) 获取 受 影响 的 行 数 

int mysqli_affected_rows ( mysqli $link ) ; 




















语法 格式 





int $mysqli->affected_rows; PA 
返回 前 一 次 MySQL 操作 (SELECT、INSERT、 VERAT aad DELETE) 所 影响 的 
记录 行 数 ， 


参数 说 明 | link: 指定 MySQL 连接 标识 。 人 X 
返回 值 | 一 个 正 整数 表示 所 影响 的 记录 行 数 。 AN 三 响 的 记录 。 -1 表示 查询 返回 错误 。 
CET 2 "m 
如 果 受 影响 的 行 数 大 于 最 大 整数 值 cae MERE THADHER TA Pin. 
664 ”处 理 查询 数据 集 1 NS 
SELECT 查询 是 把 符合 条 件 的 记录 返回 一 A ANERER 
表 对 应 。 查 询 结果 集 包含 在 一 个 名 为 m ri. 处 理 SELECT 查询 就 是 从 
Tesultset 中 提取 需要 的 数据 。 


上 人 的 人 B. 如 记录 的 行 数 、 记 录 行 数据 、 字 段 的 数据 、 数 
据 表 的 结构 ， 以 及 数据 库 中 所 含 的 数据 表 等 。 


函数 功能 


























1. MySQL 扩展 


示例 6 3 mysql.php//MySQL 扩展 





«?php 
$1link-émysql connect ("localhost","root",""); / [ERE MySQL 服务 器 
mysql query("set names 'utf8'"); // 设 置 客 户 端的 字符 集 
mysql select db("bank"); 
/ /1 获取 查询 数据 集 
$sql="SELECT *FROM bmessage"; //SQL 语句 
$result-mysql query ($sql); // 执 行 SOL 诸 句 并 把 结果 返回 给 变量 
if (mysql_errno()){ 
echo "<br /»2:".mysql errno().":".mysql error( )."<br /»"; // 检 查 错误 





exit (); 
} 
else echo "<br />1: 查 询 数 据 表 bmessage 成 功 ! <br />"; } 
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//2 获取 记录 行 数 
$num=mysql_num rows ($result); // 从 结果 集中 获取 表 中 包含 的 记录 数 
echo "<br />2: 使 用 mysql_num_rows :数据 表 中 包含 了 " .Snum. "个 记录 。<br />"; 





//3 使 用 mysqli_fetch_row 获取 记录 行 信息 

$row-mysql fetch row($result); //$result 为 查询 结果 集 
$num=mysql_num fields ($result); 

echo "<br />3: 使 用 mysql_fetch row*num fields() 获取 记录 行 信息 <br />"; 
for ($i=0;$i<$num; $i++) 








echo $row[$i]."|"; 
//4 WE} mysqli fetch array 获取 记录 行 信息 
mysql data seek($result,0); // 把 操作 指针 回 拨 到 最 前 端 位 置 


$arr-mysql fetch array($result); / /$result 为 查询 结果 集 
echo "<br /><br />4-1: 使 用 mysql fetch array dos dd 获取 记录 行 信 


息 <br />"; 
for ($i=0; $i<$num; $i++) SS 
echo $arr[S$i]." | "; 


echo "<br /><br />4-2:{#}] mysql fetch arra: aod ta seek 获取 记录 行 信息 <br /»"; 
for ($i=0; $i<$num; $i++) S 
echo Sarr[Si]." | "; 





//5 1H mysqli fetch object 获取 记录 

echo "<br /»«br />5: 使 用 mys RA object data aen 获取 记录 行 信息 "7 

mysql data seek($result, NS // 把 操作 指针 回 拨 到 最 前 端 位 置 

while ($object=mysql serk ond ject ($result) ) & $result 为 查询 结果 集 
echo "<br /»"; | Xe A X 
echo Sobject-»id. ; > » m 
echo $object [ur « r 
echo $okj -»email."|»"; DA 











echo. $object-»password; 
) XS 


//6 使 用 mysqli_fetch_assoc 获取 记录 行 信息 

echo "<br /»«br />6: 使 用 mysql_fetch_assoc+data_seek 获取 记录 行 信息 <br />"; 

mysql data seek(Sresult,0); // 把 操作 指针 回 拨 到 最 前 端 位 置 

$array-mysql fetch assoc($result); 

$str-$array['id']. "|".$array['name']."|»".$array['email']. "|".Sarray['pass 
word']; 

echo $str; 





//71 WER] mysql fetch array 获取 记录 行 信息 

echo "<br /»«br /»7:18H] mysql result 获取 记录 行 信息 <br />"; 
echo mysql result ($result,0,"id")."|"; //$result 为 查询 结果 集 
echo mysql result ($result,0,"name")."|"; 

echo mysql result($result,0,"email")."|"; 

echo mysql result ($result,O0, password"); 








mysql free result ($result); 
mysql close(); 
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若 MySQL 的 主机 ， 用 上 Jj: "localhost" 
1 :查询 数据 表 bmessage 成 功 ! 
2 :使 用 mysql1_num_rows :数据 表 中 包含 了 1 个 记录 
3: 使 用 mysql_fetch_rowtnum fields() 获取 记录 行 信息 
1| 张 三 |szhang123@126.netlasdfgh| 





4-1: 使 用 mysql_fetch_array (ASSOC) +data_seek 获取 记录 行 信息 
1 | 张 三 | szhang123@126.net | asdfgh | 


4-2: 使 用 mysql_fetch_array (NUM) +data_seek 获取 记录 行 信息 
1 | 张 三 | szhang1238126.net | asdfgh | 


5: 使 用 mysql_fetch_object+data_seek 获取 记录 行 信息 区 < 
1|9K—|szhang1238126.net|»asdfgh 


6:44) mysql fetch assoc*data seek ATTA eS 
1| 张 三 |>szhang1238126.netlasdfgh XS 
7:14HJH mysql result 获取 记录 行 信息 Wr 
1|9K-—|szhang1238126.net|asdfgh " AXi 
NS、 
D 获取 数据 表 中 记录 的 信息 “| 
语法 格式 |int mysql num rows(1 sou e Šresult ) 




















HU 各 得 结 果 入 中 行 的 类 OO S 
result: resource X4. JACI AA msa qe) MAN. 
27A. —NGNGET. 7 
» XN 
Y s Xy 
un NVs ^ A 


© SE SELECT 语句 有 效 。 
®© mysql_affected_rows() 返 回 被 INSERT. UPDATE 或 者 DELETE 查询 影响 的 行 的 数目 。 





Darray mysql. fetch row ( resource $result ); 
G)array mysql. fetch. assoc ( resource $result ); 
语法 格式 | @array mysql. fetch array ( resource $result [, int $ result. type ] ): 

GDobject mysql. fetch. object ( resource $result ); 

bool mysql. data. seek ( resource $result , int Srow. number ); 

GD 从 结果 集中 取得 一 行 作 为 枚 举 数 组 。 

回 从 结果 集中 取得 一 行 作为 关联 数组 . 

函数 功能 | 加 从 结果 集中 取得 一 行 作为 关联 数组 ， 或 数字 数组 ， 或 二 者 兼 有 。 

图 从 结果 集中 取得 一 行 作为 对 象 。 

回 将 指定 的 结果 标识 所 关联 的 MySQL. 结果 内 部 的 行 指针 移动 到 指定 的 行 号 。 

result: resource 型 的 结果 集 。 此 结果 集 来 自 对 mysql_query) 的 调用 。 

参数 说 明 | result type: 常量 。 可取 值 : MYSQL_ASSOC，MYSQL_NUM 和 MYSQL_BOTH( 默 认 ). 


Tow number: 想 要 设 定 的 新 的 结果 集 指针 的 行 数 。 取 值 应 该 从 0 到 mysql_num_rows -1. 

















@D 从 和 指定 的 结果 标识 关联 的 结果 集中 取得 一 行 数 据 并 作为 数组 返回 . 每 个 结果 的 列 储存 
在 一 个 数组 的 单元 中 ， 偏 移 量 从 0 开始 . 

回 返回 对 应 结果 集 的 关联 数组 ， 并 且 继 续 移动 内 部 数据 指针 。 

(X MYSQL ASSOC 时 ， 只 得 到 关联 索引 ( 如 同 mysql fetch assoc() 那样 ); 











BEE 取 MYSQL_NUM 时 ， 只 得 到 数字 索引 (如同 mysql. fetch row() 那样 ); 
取 MYSQL_BOTH 时 ， 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 。 
图 返回 根据 所 取得 的 行 生成 的 对 象 ， 如 果 没有 更 多 行 ， 则 返回 FALSE. 
图 成 功 时 返回 TRUE， 失 败 时 返回 FALSE. 
Lun 


@ 依次 调用 mysql_fetch_row0 将 返回 结果 集中 的 下 一 行 ， 如 果 没 有 更 多 行 ， 则 返回 FALSE. 

Q 如 果 结 果 集中 的 两 个 或 以 上 的 列 具有 相同 字段 名 ， 最 后 一 列 将 优 访问 同名 的 其 他 列 ， 要 么 
用 mysql_fetch_row() 来 取得 数字 索引 或 给 该 列 起 个 别名 。 X 

O 返回 的 字段 名 大 小 写 敏感 。 AN 

图 引用 对 象 属性 的 语法 : Sobject-> 字 段 名 . 

© 如 果 结果 集 为 空 mysqlL_num_rows() 一 0)， guit. < 
误 ，mysql_data_seek() 将 返回 FALSE. 


^ J 
2) 获取 字段 的 数据 


语法 格式 mime esi 
int mysql field seek ( resou ult , int $field. offs 
返回 MySQL 结果 集中 一 个 单元 的 内 容 。 x 
1 


将 结果 集中 的 指针 设 定 为 指定 的 字段 偏 移 量 K 
Result: IS 此 结果 集 i 的 调用 . 
参数 说 明 | row: ge fri. X ND 
ss. X 
返回 值 “| 如 果 执行 成 功 ， 则 返回 查询 结果 集中 指定 字段 值 ， 如 果 执 行 失败 ， 则 返回 FALSE， 
如 果 执 行 成 功 ， 则 指针 指向 查询 结果 集中 指定 的 字段 。 
un 


O 字段 参数 可 以 是 字段 的 偏 移 量 或 者 字段 名 ,或 者 是 字段 表 . 字 段 名 ( tablename.fieldname )。 如 果 给 
列 起 了 别名 ('select foo as bar from.… )， 则 用 别名 替代 列 名 。 

© 在 字段 参数 中 指定 数字 偏 移 量 比 指定 字段 名 或 者 tablename.fieldname 要 快 得 多 。 

© 当 作 用 于 很 大 的 结果 集 时 ， 应 该 考虑 使 用 能 够 取得 整 行 的 函数 。 

图 不 能 和 其 他 处 理 结果 集 的 函数 混合 调用 。 


3) 释放 结果 集 占据 的 内 存 
语法 格式 | bool mysql. free. result ( resource $result ); 
函数 功能 | 释放 所 有 与 结果 标识 符 result 关联 的 内 存 。 


参数 说 明 | result: resource 型 的 结果 集 。 此 结果 集 来 自 对 mysqli_query() 的 调用 。 
返回 值 | 成 功 时 返回 TRUE， 失 败 时 返回 FALSE. 


会 失败 并 发 出 E_WARNING 级 的 错 








函数 功能 
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需要 在 考虑 到 返回 很 大 的 结果 集 时 会 占用 多 少 内 存 时 调用 . 在 脚本 结束 后 所 有 关联 的 内 存 都 会 被 自动 
释放 。 





2. MySQLi 扩展 


3_mysqli.php//MySQLi $ HE (1h 





<?php 
$link-mysgli connect("localhost","root","","bank");  //3&f MySQL 服务 器 
mysqli query($link,"set names 'utf8'");; 























//1 获取 查询 数据 集 
$sql="SELECT *FROM bmessage"; //SQL 语句 
$result-mysqli query($link,$sq1);  // 执 行 SQL ps a 器 给 变量 
if(mysqli errno(Slink))( 
echo "<br /»2:".mysqli errno($link).":" vé error($link)."«br /»"; 
// 检 查 错 误 AD 
exit (); HN 
) 
else echo "<br />1: 查 询 数据 表 bmess s /»"; 
//2 获取 记录 行 数 E 


$numemysqli num IM, // 从 结果 集中 获取 表 中 包含 的 记录 数 

echo "«br />2: 使 用 mysql OWS: 数据 表 中 包含 了 ? .Snum. "个 记录 。<br /»"; 
//3 使 用 e A 记录 行 信息 

$rowemysqli fetch JWA ($result); ; vns vanana 
Sn ($result); 

echo "<br /»3:1EH] nyse fetch gory Naieaas () 获取 记录 行 信息 <br /»"; 


for ($i-0;Si4Snum; $i++) NL 
sera korisa." f 
//A WX] mysqli fetch array 获取 记录 行 信息 


mysgli data seek($result,0); // 把 操作 指针 回 拨 到 最 前 端 位 置 
$arr-mysqli fetch array($result);  //$result 为 查询 结果 集 
echo "<br /><br />4-1: 使 用 mysqli_fetch_array(ASSOC) +data_seek 获 取 记 录 行 信息 <br />"; 
for ($i=0; $i<$num; $i++) 
echo $arr[$i]." | "; 
echo "<br /»«br /»4-2:1kJljmysqli fetch array(NUM)-*data seek 获取 记录 行 信息 
<br /»"; 
for ($i=0; $i<$num; $i++) 
echo $arr[$i]." | "; 
//5 18i mysqli fetch object 获取 记录 行 信息 
echo "<br /»«br /»5:[k]]]mysqli fetch object*data seek 获取 记录 行 信息 "; 
mysqli data seek ($result,0); // 把 操作 指针 回 拨 到 最 前 端 位 置 
while($object=mysqli_fetch object ($result) ){ //Sresult 为 查询 结果 集 
echo "<br /»"; 
echo $object-»id."|"; 
echo $object-»name."|"; 
































echo $object-»email."|»"; 
echo $object-»password; 





//6 使 用 mysqli fetch assoc 获取 记录 行 信息 


echo "<br /><br /»6:15Himysqli fetch assoc*data seek 获取 记录 行 信息 <br /»"; 
mysqli data seek($result,0); 





// 把 操作 指针 回 拨 到 最 前 端 位 置 
Sarray-mysqli fetch assoc($result); 
$str-$array['id']. "|".$array['name']."|»".$array['email']. "|".$array 
['password']; 


echo $str; 
mysqli free result ($result); 
mysqli_close ($link); 














示例 6_3_mysqlio.php//MySQLi 扩展 (面向 对 象 
«?php 


$mysqli-new mysqli ("localhost","root", Aie ; / [ERE MySQL 服务 器 


// 设 置 客户 端的 字符 集 





$mysqli-»query("set names 'utf8'"); 
/ /1 获取 查询 数据 集 N wd 
$sql-"SELECT *FROM bnessager? //SQL 语句 


$result-: 7Smysqli-»query (Ss; AC xt sor 语句 并 把 结果 返回 给 变量 
if ($mysqli->errno) DA Tt YX 


fs 
echo "«br /»2:" ee -»error."«br /»"; // 检 查 错误 


l mo, A "NO 


else T "px /»1: Lu 成 功 ! «br /»";; 





E 














//2 获取 i 


$num-$résult-»num rows; // 从 结果 集中 获取 表 中 包含 的 记录 数 

echo "<br />2: 使 用 mysql->result: :num_rows :数据 表 中 包含 了 " .Snum." 个 记录 。<br /»"; 
//3 使 用 mysql->result: :fetch_row 获取 记录 行 信息 

$row-$result-»fetch row( ); / /$result 为 查询 结果 集 
$num-$result-»field count; 





echo "<br />3:{#H] mysql-»result::fetch row()*field count 获取 记录 行 信息 <br />"; 
for ($i=0;$i<$num; $i++) 
echo $row[$i]."|"; 





//4 WEH] mysql-»result::fetch array 获取 记录 行 信息 
$result-»data seek(0); // 把 操作 指针 回 拨 到 最 前 端 位 置 


Sarray-$result-»fetch array(); 

echo "<br /><br />4-1: 使 用 mysql-»result::data seek()*fetch array() MYSOL 
ASSOC 获取 记录 行 信息 <br /»"; 

$str-$array['id']. 
['password']; 

echo $str; 


"|".$array['name']."|»".$array['email']. "|".$array 








echo "<br /»«br />4-2: 使 用 mysql->esult::data seek()*fetch array() MYSQL NUM 








© 
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获取 记录 行 信息 <br />"; 
for ($i=0;$i<$num; $i++) 
echo $array[$i]." | "; 





//5 fli] mysql-»result:fetch objectc 获取 记录 行 信息 
echo "<br /»«br />5: 使 用 mysql->result: :data_seek ()+fetch_object () 获取 记录 行 信息 "; 
$result-»data seek(0); // 把 操作 指针 回 拨 到 最 前 端 位 置 
while ($object=$result->fetch_object()) ( //$result 为 查询 结果 集 
echo "«br /»"; 
echo $object-»id."| 
echo $object-»name. 
echo $object-»email."|»"; 
echo $object-»password; 
) 














//6 使 用 mysql1->result::fetch_ assoc 获取 记录 行 信息 pr 
echo "<br /»«br />6: 使 用 mysql->result::data E dm assoc( ) 获 取 记 











录 行 信息 <br />"; We 
$result-»data seek(0); 指针 回 拨 到 最 前 端 位 置 
$Sarray-Sresult-»fetch assoc( ); 
$str-S$array['id']. "|".S$array['name N $array['email']. "|".$array 
['password']; AS 
echo $str; PES NN 
$result->free result( ); 
$mysqli-»close( ); X 
?> > NA 
运行 结果 ”车 MySQL 的 主机 ， 用 户 和 密码 是 "localhost","root"."" 
v V 
fel 6.3. mysql.php 的 前 x 
D 获取 数据 表 毕 记录 的 信息 o o NS 








语法 格式 4 让 | rows ( mysqli_result A int Smysqli_result ->num_rows; 





函数 功能 | 取得 结果 集中 行 的 数目 。 








参数 说 明 | Result: resource 型 的 结果 集 。 此 结果 集 来 自 对 mysqli_query( ) 的 调用 。 





S un 


@ 此 命令 仅 对 SELECT 语句 有 效 。 
@ 若 行 的 数目 大 于 PHP_INT_MAX， 则 将 返回 一 个 字符 囊 。 





© int mysqli_num_rows ( mysqli_result $result ) ; int $mysqli_result ->num_rows; 

加 array mysqli_fetch_assoc(mysqli_result $result); array mysqli_ result::fetch_assoc(void); 
(8) mixed mysqli_fetch_array ( mysqli_result $result [, int $resulttype = MYSQLL BOTH ] ); 
(S) mixed mysqli_result::fetch_array ([ int $resulttype = MYSQLL BOTH ] ) 

语法 格式 | (D object mysqli fetch object(mysqli result $result [, string Sclass  name-"stdClass" [, array 


Sparams]]) 
(à) object mysqli result::fetch. object ([stringSclass name- "stdClass" [.arraySparams ]] ) 
(8) bool mysqli. data. seek ( mysgli. result $result , int Soffset ); mysgli. result::data, seek 


(intSoffset); 
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@D 从 结果 集中 取得 当前 行 作为 枚 举 数 组 。 

回 从 结果 集中 取得 当前 行 作为 关联 数组 。 

函数 功能 | @@ 从 结果 集中 取得 当前 行 作为 关联 数组 ， 或 数字 数组 ， 或 二 者 兼 有 . 

@@ 从 结果 集中 取得 当前 行 ， 并 作为 对 象 返 回 -。 

轿 将 指定 的 结果 标识 所 关联 的 MySQL 结果 内 部 的 行 指针 移动 到 指定 的 行 号 。 

result: resource 型 的 结果 集 。 此 结果 集 来 自 对 mysqli_query() 的 调用 。 

class_name: 规定 要 实例 化 的 类 名 称 ， 设 置 属性 并 返回 。 若 没有 制定 ， 则 返回 stdClass 
A. 

params: 规定 一 个 传 给 class name 对 象 构造 器 的 参数 数组 。 

resulttype: 常量 。 可 取 值 : MYSQL_ASSOC，MYSQL_NUM 和 MYSQL_ BOTH( 默 认 )， 
offset; 想 要 设 定 的 新 的 结果 集 指 针 的 行 数 。 取 值 应 该 从 0 到 mysql num. rows -1. 

@D 一 个 与 所 取得 行 相 对 应 的 字符 囊 数 组 .如果 在 结果 集中 没有 更 多 的 行 ， 则 返回 NULL. 
加 代表 读 取 行 的 关联 数组 。， 如 果 结 果 集中 没有 更 多 的 行 ， 则 返回 NULL. 
人 @@ 与 读 取 行 匹配 的 字符 串 数组 ， 如 果 结 果 集中 没有 更 多 me 回 NULL, 
当 取 MYSQL ASSOC 时 ， 只 得 到 关联 索引 ( 如 同 ferch assoc( ) 那样 








参数 说 明 











ZEN 当 取 MYSQL. NUM 时 ， 只 得 到 数字 索引 ( 如 同 feteh_row( ) 那样 ); 
当 取 MYSQL_BOTH 时 ， 得 到 一 个 同时 包 字 索 引 的 数组 。 
@ 带 有 所 取得 行 的 字符 事 属 性 的 对 象 。 HERE E ESI, 则 返回 NULL. 
回 成 功 时 返回 TRUE， 失 败 时 返回 parse, ! 
7 
« 说 明 SS 


© 依次 调用 fetch. row) 桂 返回 结案 中 的 下 一 生 ， pe 则 返回 FALSE. 

@ 如 果 结果 中 的 两 个 或 以 上 的 列 具 有 相同 字段 名 ， 最 后 一 列 将 优先 。 要 访问 同名 的 其 他 列 ， 要 么 
用 fetch_row() 来 取得 数字 索引 或 给 该 列 起 个 别名 . Ww L 

O dcm RUE od S ao. ae 

© 引用 对 象 属性 的 语法 : Sobjecto HER, DO s 

© 如 果 结果 集 为 室 (num_rows0==0)， Paea 0 会 失败 并 发 出 E WARNING 级 的 错误 ， 
data seek() 将 返 SE. 


2) 释放 结果 集 占据 的 内 存 


void mysqli_free_result ( mysqli_result $result ); 

语法 格式 | void mysqli_result::free_result ( void ); 

void mysqli_result::close ( void ); void mysqli_result::free ( void ); 
函数 功能 | 释放 结果 集 占据 的 内 存 。 

参数 说 明 | result: resource 型 的 结果 集 。 此 结果 集 来 自 对 mysqli_query() 的 调用 。 


Lun 
当 不 需要 结果 集中 的 数据 时 ， 要 及 时 回收 内 存 。 
6.6.5 ”查询 数据 表 的 结构 


数据 表 的 结构 包括 字段 的 个 数 、 字 段 的 名 称 、 字 段 的 数据 类 型 、 字 段 的 长 度 、 字 段 的 
标志 等 。 




















o 第 6 章 网 上 社区 设计 与 PHP 数据 库 访问 


o eB Pd 





1. MySQL 扩展 
6. 4 mysql.php//MySQL 扩展 
«?php 
$link-8mysql connect ("localhost","root",""); // 连 接 MySQL 服务 器 
mysql query("set names 'utf8'"); // 设 置 客户 端的 字符 集 





mysql select db("bank"); 
//1 获取 查询 数据 集 
// 同 6_4_mysql.php 
//2 获取 数据 表 bmessage 中 字段 的 个 数 
$num=mysql_num fields($result);  // 从 结果 集中 获取 表 中 包含 的 记录 数 
echo "<br />2: 数 据 表 中 包含 了 " .Snum. "个 字段 。<br />"; 
/1/3 使 用 mysql_field_name 获取 极端 的 名 称 
echo "<br />3 使 用 mysql_field_name 获取 极端 的 名 称 。 br ex 











for($i-0;$i« mysql num fields ($result); ANN $result 为 查询 结果 集 
$name[$i]-mysql field name ($result, $i); 
echo $name[$i]." | "; AS 


/ 








) 
//4 Jil mysql, field type 获取 极端 的 
echo "<br />4 使 用 mysql_fielad : 
for($i-0;Si«mysql num field 


$type[$i]=mysql fiel typi 
echo $type[$i]." E 


XS 
) d 
/15 使 用 mysql fi A VA L 


echo "<br />5 使 用 1_field_len 获 mie. <br /»"; 
for($i-0; d num fields ($result)2$i+t+){ — // $result 为 查询 结果 集 


$len. 1 field len($réSult; $i); 
Semi [$1] ." | "S; | 


m fij] mysql field flags 获取 字段 的 标志 

echo "<br />6 fkJ]]mysql field flags 获取 字段 的 标志 。<br /»"; 

for($i-0;$i«mysql num fields ($result);$i++){ // $result 为 查询 结果 集 

if($flags=mysql_field flags ($result,$i)) // 获 取 字 段 属性 并 赋 给 变量 
echo "第 ".$i." 字 段 的 MySoL 标记 : $flags«br /»"; // 显 示 字 段 的 MySQL 标记 





端的 数据 类 型 。<br /»"; 
sult);Sie*)( — // $result 为 查询 结果 集 
esult,$i); 














) 
//148R] mysql fetch field 获取 字段 的 信息 
echo "<br />7 使 用 mysql_fetch_field 获取 字段 的 信息 。<br /»"; 
for($i-0;Si«mysql num fields (Sresult) ;Si++){  // $result 为 查询 结果 集 
$field- mysql fetch field($result,$i); 
echo "第 " .$i." 字 有 段 的 信息 : «br /»"; 


echo "<pre> 





table: $field->table 
fieldname: $field->name 
fieldtype: $field->type 


max length: $field->max length 
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multiple key: $field-»multiple key 
primary key: S$field->primary key 
unique key:  Sfield-»unique key 





unsigned: $field-»unsigned 
zerofill: Sfield-»zerofill 
not null: Sfield-»not null 
numeric: $field-»numeric 
</pre>"; 


) 
mysql close(); 











用 户 和 





1 查询 数据 表 bmessage 成 功 ! 
2 数据 表 中 包含 了 4 个 字段。 K 
3 使 用 mysql_field_name 获取 字段 的 名 称 。 


int | string | string | string | 


54H] mysql field len 获取 字段 的 长 度 。 


10 | 60 | 120 | 60 | 
61H)f] mysql field flags 获取 字 F. 
第 0 字段 的 MySQL 标记 : not n ry key auto increment 
第 1 字段 的 MysQL 标记 ; T 

第 2 字段 的 MySQL 标记 : Xs 

第 3 字段 的 MYSQL bri Wt 
7 使 用 mysql_fet 获取 字段 的 信息 。 


fe 
第 0 muc. 


id | name | email | password | S 
4 使 用 mysql field type 获取 字段 的 数据 类 型 。 xv 


table: 
fieldn q id 
fieldtypé: int 


max length: 1 
multiple key: 0 
primary key: 1 
unique key: 0 


unsigned: 0 
zerofill: 0 
not null: 1 
numeric: di 





int mysql num fields ( resource Sresult ) 

string mysql field name ( resource $result , int Sfield offset ) 
string mysql. field type ( resource $result , int Sfield offset ) 
int mysql. field len ( resource $result , int Sfield offset ) 
object mysql fetch field ( resource Sresult [ int Sfield offset ] ) 
string mysql field flags ( resource $result , int Sfield offset ) 


语法 格式 
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取得 结果 集中 字段 的 数目 - 
返回 指定 字段 索引 的 字段 名 称 。 
返回 指定 字段 索引 的 字段 数据 类 型 。 
函数 功能 | 返回 指定 字段 索引 的 字段 宽度 。 
返回 指定 字段 索引 的 字段 信息 .。 
返回 指定 字段 索引 的 字段 标志 。 
Result: resource 型 的 结果 集 。 此 结果 集 来 自 对 mysql_query) 的 调用 。 
参数 说 明 | feld ofset: 数值 型 字段 偏 移 量 ， 从 0 开始， 依次 对 应 第 1.2,，. 个 字段 。 
如 果 执 行 成 功 ， 则 返回 查询 结果 集中 字段 的 数目 ;如果 执行 失败 ， 返 回 FALSE. 
如 果 执 行 成 功 ， 则 返回 查询 结果 集中 指定 字段 的 名 称 ; 如果 执行 失败 ， 返 回 FALSE. 
"T 如 果 执 行 成 功 ， 则 返回 查询 结果 集中 指定 字段 的 类 型 ; 如果 执行 失败 ， 返 回 FALSE. 

如 果 执 行 成 功 ， 则 返回 查询 结果 集中 指定 字段 的 宽度 ; 如 果 执 行 失败 ， 返 回 FALSE. 
如 果 执行 成 功 ， 则 返回 查询 结果 集中 指定 字段 信息 的 对 象 ; 如 果 执 行 失败 ， ie FALSE. 
如 果 执 行 成 功 ， 则 返回 查询 结果 集中 指定 字段 的 标志 ; 如 果 行 失败 ， 返回 FALSE. 


TM S 


(D 配合 mysql field name(),mysql. field. len(), my ftis mq fach fei mysql. field. flags() 
以 获取 字段 的 单独 属性 。 N 

®© mysql_field_name() 返 回 的 字段 名 大 小 S808. X, 

图 mysql_field_type() 返 回 的 字段 类 型 有 i ins el. string. blob 及 其 他 。 

G) 如 果 field. offset 不 存在 ， 则 会 发 出 一 个 E_WARNING 级 别 的 错误 . 

© mysql_fetch_fields() 返 回 field. eo iln — inim 如 表 6.19 所 示 。 
































J em field 对 象 属性 


Y 





属 性 说 明 

name li — — Fou. 字段 所 属 的 数据 表 名 称 

type emma F 若 字段 不 接受 无 效 数据 ， 则 返回 1 
max length | blob [FEH blob 数据 类 型 ， 则 返回 1 
primary key. | 郑 字段 是 主键 ， 则 返回 1 | unsigned | FEA unsigned 数据 类 型 , 则 返回 1 
unique_key 若 字段 为 数据 需要 补 0， 则 返回 1 


multiple key | 车 字段 不 是 唯一 的 , 则 返回 1 numeric ATE BUS numeric 数据 类 型 ， 则 返回 1 


(D 每 个 标志 都 用 一 个 单词 表示 ， 之 间 用 一 个 空格 分 开 ， 可 以 用 explode() 将 其 分 开 。 
Q) field_offse 从 0 开始 ，0 对 应 第 一 个 字段 ，1 对 应 第 二 个 字段 ， 依 此 类 推 . 


2. MySQLi 扩 展 


示例 6.4. mysgli.php//MySQLi 扩展 (面向 过 程 ) 





<?php 
$link-mysqli connect ("localhost", "root","", "bank"); / /连接 MySQL 服务 器 
mysqli query ($link,"set names 'utf8'"); // 设 置 客户 端的 字符 集 








pps E Sepe no D 








//1 获取 查询 数据 集 
// 同 6_4_mysqli.php 
//2 获取 数据 表 bmessage 中 字段 的 个 数 
$num-mysqli num fields ($result); // 从 结果 集中 获取 表 中 包含 的 记录 数 
echo "<br />2 :数据 表 中 包含 了 " .Snum. "个 字段 。<br /»"; 
//3 使 用 mysqli_fetch_field 获取 字段 的 标志 
echo "<br />3 使 用 mysqli_fetch_field 获取 字段 的 标志 。"; 











echo "<br /> Table | Name | max. Len | Flags | Type"; 
while ($finfo = mysqli fetch field($result)) { 

echo "<br />  ".S$finfo-»table; 

echo " | ".$finfo-»name; 

echo " | ".$finfo-»max length; 

echo" | ".$finfo-»flags; 


echo" | ".$finfo-»type; 
) 
//A E] mysqli fetch fields 获取 字段 的 信息 
echo "<br /»«br />4 使 用 mysqli_fetch. m 








$finfo = mysqli fetch erar 


echo"«br/» Table | Name AN- | Type | Length | charsetnr"; 
foreach ($finfo as uA 

echo "<br /> ".$val-5t Ku 

echo " | ".$val- >name; 

echo " | " .$val-> La 

echo” j 7 Syal SiG ee 





echo" Ne zi eame: X 

echo " DS l-»length; X IS 4 
echo | "fisvalc»charsetnrj. d 

) 7 

mysqli free result ($result); 


mysqli_close ($link); 














E dt MySQL h3 
1 查询 数据 表 bmessage 成 功 ! 
2 数据 表 中 包含 了 4 个 字段 。 
3 使 用 mysqli_fetch_field 获取 字段 的 标志 。 
Table | Name | max. Len | Flags | Type 
bmessage | id | 1 | 49667 | 3 
bmessage | name | 6 | 128 | 253 
bmessage | email | 17 | 128 | 253 
bmessage | password | 6 | 128 | 253 


4 使 用 mysqli_fetch fields 获取 字段 的 信息 。 

Table | Name | max. Len | Flags | Type | Length | charsetnr 
bmessage | id | 1 | 49667 | 3 | 10 | 63 

bmessage | name | 6 | 128 | 253 | 60 | 33 
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bmessage | email | 17 | 128 | 253 | 120 | 33 
bmessage | password | 6 | 128 | 253 | 60 | 33 





qliphp//My 
<?php 
$mysqli-new mysqli ("localhost", "root","", "bank") ; // 连 接 MySQL 服务 器 
$mysqli-»query("set names 'utf8'"); // 设 置 客户 端的 字符 集 





//1 获取 查询 数据 集 
// 同 6_4_mysqlio.php 
//2 使 用 mysqli_result:: field count 获取 数据 表 bmessage 中 字段 的 个 数 
$num-$result-»field count;  // 从 结果 集中 获取 表 中 包含 的 记录 数 
echo "<br />2: 数 据 表 中 包含 了 " .$num. "个 字段 。<br />"; 
//3 使 用 mysqli_result::fetch field 获取 字段 的 标志 
echo "<br />3 使 用 mysqli_result::fetch field HCM i. "i 











echo "«br /» Table | Name | max. Len REN | Type"; 
while ($finfo = $result->fetch field() 
echo "<br /> ".$finfo->table; / AS 
echo" | ".$finfo-»name; WV 
echo" | ".$finfo-»max le S 
echo" | ".S$finfo- ^flag SA 
echo " | ".$finfo- — 





) Ave 
/1/4 使 用 mysqli . ERES fields 获取 字段 和 "S 


echo "«br /»«br /»4 MR mysql. result : ch“ fields 获取 字段 的 信息 。 





$finfo = $result ch fields(); NG 
echo "<br /> Táble | Name | max. N vägs | Type | Length | charsetnr"; 
foreach tinto as $val) ( xL A 

echo- /> ".$val-»table; “| 

echo " ".$val-»name; 

echo " ".$val-»max length; 

echo " ".$val-»flags; 


".$val-»length; 
".$val-»charsetnr; 


l 

1 

1 
echo" | ".$val-^5type; 
echo l 
echo 1 


) 
$result free-»result(); 





$mysqli-»close(); 











E 6 5 mysgqlio.php 





intmysqgli num fields ( mysgli result Sresult); int $mysqli_ result-7field count; 
语法 格式 object mysqli_fetch_field ( mysqli_result Sresult); object mysqli_result::fetch_field ( void ); 
array mysgli fetch fields ( mysqli result $result ); array mysgli. result::fetch fields ( void ); 
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取得 结果 集中 字段 的 数目 。 

函数 功能 | 从 结果 集中 取得 下 一 字段 ( 列 ). 

返回 指定 结果 集中 关于 数据 表 的 字段 属性 。 

参数 说 明 | result: resource 型 的 结果 集 。 此 结果 集 来 自 对 mysgli. query() 的 调用 。 

整数 ， 查 询 结果 集中 字段 的 数目 。 

返回 值 “| 一 个 对 象 ， 包 含 字段 定义 的 信息 。 如 果 没 有 定义 字段 信息 ， 则 返回 FALSE. 

一 个 对 象 的 数组 ， 包 含 了 字段 定义 的 信息 。 如 果 没有 定义 字段 信息 ， 则 返回 FALSE. 














Lun 





C mysqli num fields() 544-5 field count 对 应 ，field_count 是 mysqli_result 类 的 属性 。 
回 fetch_field 与 fetch_fields 的 区 别 : fetch field 返回 一 个 对 象 ，fetch_fields 返回 的 列 为 对 象 的 数组 。 
返回 对 象 包 含 的 属性 如 表 6.20 所 示 。fetch_fields 缺少 了 def, db 和 “os 


表 6.20 fied 对 象 包含 的 属性 、 


orgname 
charsetnr 


max, length 








catalog | 目录 名 称 ， 总 是 为 "def (H PHP 5.3.6 RD 六 p 
xc X à 


^ 
dis a 37 


> 
字段 的 宽度 (Length) 使 用 的 数字 ( 字 节 ) 可 能 与 表 定 义 值 (字符 ) 不 同 ， 这 取决 于 使 用 的 字符 集 。 例 如， 字 
符 集 utf8 每 字符 3 个 字 节 ， 所 以 varchar (10) 将 返回 UTF8 长 度 为 30 (10x3 )， 而 数字 1 返回 的 是 10。 


6.6.6 ”查询 数据 库 的 结构 


查询 数据 库 的 结构 ， 列 出 当前 MySQL 服务 器 上 包含 的 数据 表 和 指定 数据 库 中 包含 的 











1. MySQL 扩展 
示例 6.5. mysql.php//MySQL 扩展 
«?php 
$1link-8mysql connect ("localhost","root",""); // 连 接 MySQL 服务 器 
mysql query("set names 'utf8'"); // 设 置 客户 端的 字符 集 
//1 获取 数据 库 服务 器 中 包含 的 数据 库 
//$dblist-mysqgl list dbs ($link); // 获 取 可 用 数据 库 名 称 的 结果 集 


$sql-"SHOW DATABASES "; 
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$dblist=mysql_query ($sql); 

echo "<br />1. 获 取 数 据 库 服务 器 中 包含 的 数据 库 。<br /»"; 

while ($row = mysql fetch object ($dblist)) // 从 结果 集中 ， 获 取 数 据 库 名 称 

echo $row-»Database . "<br \>"; 

//2 获取 bank 数据 库 中 包含 的 数据 表 
echo "<br />2. 获 取 bank 数据 库 中 包含 的 数据 表 。<br /»"; 
$tblist=@mysql_ list tables ("bank"); // 获 取 指定 数据 库 中 包含 数据 表 的 结果 集 
$n- mysql num rows ($tblist); // 从 结果 集中 ， 获 取 数 据 表 的 个 数 
for ($i=0; $i<$n; $i++) 

echo mysql_tablename ($tblist,$i)."<br /»";  // 从 结果 集中 ， 获 取 数 据 表 名 称 


mysql close(); 























bank 


bookshop 
chat s N R 


1. 获取 数据 库 服 务 器 中 包含 的 数据 库 。 SS < 


guest 


member ~ XS 
mysql R 
test 


2. 获取 bank 数据 库 中 包含 的 数 v 
bmessage ~U x XN 


语法 格式 Tesource m | list dbs ([ resource Seide]. Á 
Slink_ identifier ]) 


mes 


| 列 出 My L 数据 库 中 的 表 .。 A 
Pi tes 指定 MySQL 连接 标识 . 
Database: 指定 连接 标识 的 服务 器 上 的 一 个 数据 库 。 
返回 什 | 一 个 结果 指针 ， 包 含 了 当前 MySQL 进程 中 所 有 可 用 的 数据 库 。 


一 个 结果 指针 ， 包 含 了 当前 MySQL 进程 中 数据 库 包含 的 数据 表 。 




















y 
un 
用 mysql_tablename() 函数 或 使 用 结果 表 的 函数 ， 如 mysql_fetch_array() 来 遍历 此 结果 指针 。 
配合 mysqlL_num_rows() 获 取 数 据 表 的 个 数 ; 配合 mysql_tablename() 获 取 数 据 表 的 名 称 。 
2. MySQLi 扩展 


在 MySQLi 扩展 中 ， 没 有 直接 数据 库 和 表 的 函数 或 方法 。 可 以 用 命令 SHOW 
DATABASES 和 SHOW TABLES 来 实现 该 函数 的 功能 。 





示例 6_.5_mysqli.phpWMySQLi 扩 展 〈 面 向 过 程 ) 


<?php 
$link=mysqli_connect ("localhost", "root","", "bank"); // 连 接 MySQL 服务 器 
mysqli query($link,"set names 'utf8'"); // 设 置 客户 端的 字符 集 
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/ /1 获取 数据 库 服务 器 中 包含 的 数据 库 

$sql="SHOW DATABASES;"; 

$dblist-mysqli query ($link, $sql); 

echo "<br />1 .获取 数据 库 服 务 器 中 包含 的 数据 库 。<br /»"; 

while ($row = mysqli_fetch_object ($dblist)) // 从 结果 集中 ， 获 取 数 据 库 名 称 
echo $row->Database . "<br \>"; 

//2 获取 bank 数据 库 中 包含 的 数据 表 

echo "<br />2 .获取 bank 数据 库 中 包含 的 数据 表 。<br /»"; 

$result = mysqli query( $link,"SHOW TABLES"); 

while ($row = mysqli fetch array ($result) ) 











echo $row[0].""; 





mysqli close ($link); 












运行 结果 ”车 MySQL 的 主机 ， 用 户 和 密码 是 "localhost","root","" 


同 6.5. mysql.php 







示例 6.5 mysqlio.php//MySQLi 扩展 (面向 对 象 ) 







<?php 7 
$mysqli-new mysqli ("localhost"," ox, "","bank"); // 连 接 MySQL 服务 器 
$mysqli-»query("set names ' "re // 设 置 客户 端的 字符 集 





/11 获取 数据 库 服 务 器 中 包含 的 数据 库 a 

$sql-"SHOW DATABASES; ";\ A 

$dblist-$mysqli-»quer (5381); XP A 

echo "<br />1 .获取 数据 o e J>"; 

while ($row -$db ezret oh ebi cA 7 从 结果 集中 ， 获 取 数 据 库 名 称 
echo $r Database * "nen: 

//2 获取 aik 数据 库 中 包含 的 数据 表 。 

echo "<b 2 .获取 bank 数据 库 中 包含 的 数据 表 。<br /»"; 

$result = $mysqli->query ("SHOW TABLES"); 

while ($row =$result->fetch array()) 

echo $row[0].""; 














$mysqli-»close(; 





tJ; MySQL 的 主机 ， 用 户 和 密码 
同 6 5 mysql.php 





6.6.7 ”其 他 数据 管理 工具 


1. PostgreSQL 

与 MySQL 一 样 ，PostgreSQL 是 一 个 开源 数据 库 管理 系统 ， 提 供 以 下 功能 。 

(1) 外 键 : 自动 拒绝 对 数据 库 进 行将 会 破坏 数据 库 结构 的 更 改 。 

(2) 子 选项 :可 执行 复杂 的 查询 ， 能 够 最 大 限度 地 减 小 在 网 络 上 发 送 的 结果 集 。 
(3) 事务 : 避免 应 用 一 组 有 关 的 数据 库 更 改 而 导致 数据 的 破坏 。 
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(4) 触发 器 : 在 任何 特定 事件 发 生 时 可 以 指定 数据 库 服务 器 执行 的 操作 。 

(5) 视图 : 很 方便 地 向 特定 用 户 提供 对 数据 库 子 集 的 访问 。 

PHP 也 提供 了 类 似 MySQL 的 函数 ， 用 以 实现 对 PostgreSQL 数据 库 的 访问 和 管理 。 
2. ODBC 


ODBC(Open Database Connectivity， 开 放 数 据 库 连接 ) 是 由 Microsoft 公司 开发 的 标准 ， 
广泛 地 使 用 于 Microsoft 公司 的 操作 系统 和 UNIX/Linux 操作 系统 。ODBC 提供 了 访问 数据 
库 所 必需 的 一 切 功能 ， 每 一 个 商业 数据 库 管 理 系统 和 大 多 数 非 商业 数据 库 管理 系统 都 提供 
ODBC 驱动 程序 。 

Microsoft 公司 的 操作 系统 提供 内 置 的 ODBC 支持 。UNIX/Linux 操作 系统 下 ， 必 须 安 
装 一 个 从 ODBC 到 ODBC 的 桥 或 者 其 他 一 些 支 持 ODBC 的 功能 。- 

ODBC 的 商业 解决 方案 包括 Openlinc(www.openlinkesvicom) ^70 E 
ODBCSocketServer(sourceforge.net) 

PHP 也 提供 了 一 组 内 置 函数 实现 对 ODBC VN 

ANB 


3. LDAP 











LDAP(Lightweight Directory Access Pr otocol,. ra 目录 访问 协议 ) 特 别 适 合 于 存储 目 
录 ， 即 人 员 和 组 织 及 它 介 OT LX T 
用 户 的 信息 。 

LDAP 提供 了 复制 NE^ DAIRE OAN SENEESE 处 理 任 
务 的 负载 平衡 SA v^ 

4. XML aT AN 

XML(Extensible Markup Language, SER icit to DABRINA, 能 够 描 
述 数据 的 结构 。 支持 xpat 库 。 人 允许 构造 一 个 XML 文档 的 “解析 器 ”解析 器 理解 XML 
文档 的 语法 ， 并 且 可 以 识别 组 成 文档 的 结构 组 件 。 通 过 将 一 个 函数 与 每 一 个 组 件 类 型 关联 
起 来 ， 可 以 将 解析 器 配置 为 处 理 或 转换 XML 文档 。 


5. X46 


PHP 的 库 相 当 广 泛 , 支持 的 其 他 数据 管理 工具 还 包括 dBase, DBM, Dbx, DOM XML, 
FrontBase、filePro 和 mSQL 等 。 


Cs 


通过 学 习 本 章 案例 ， 对 PHP 访问 MySQL 数据 库 有 所 认识 ， 也 能 体会 到 动态 网 页 的 本 
(1) PHP 访问 MySQL 数据 库 的 机 制 和 步骤 。 

(2) PHP 对 MySQL 数据 库 访问 的 MySQL 扩展 和 MySQLi 扩展 的 功能 和 用 法 。 

(3) PHP 对 数据 的 管理 ， 也 能 用 类 似 访问 MySQL 数据 库 的 方法 访问 其 他 数据 库 。 
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(1) 总 结 PHP 调用 MySQL 数据 库 的 步骤 。 

(2) 画图 说 明 在 PHP--MySQL 的 Web 系统 中 处 理 数据 的 流程 。 

(3) 编写 程序 代码 ， 建 立 以 (root,1234) 身 份 访问 MySQL 数据 库 “Music” 的 连接 ， 并 选 
择 这 个 数据 库 和 关闭 这 个 数据 库 。 


€ nas 


项 目 6-1 dde DN S ] 
项 目 目 标 : IS 
(1) 展示 一 个 访问 MySQL 数据 库 的 完整 程序 。 AN 

O 演示 支持 浏览 的 数据 库 编程 技术 。 N 
Bg / 
(1) 在 MySQL IRR LOO eit 的 数据 库 ， 再 在 其 下 创建 数据 表 
addressbook 并 插入 数据 ， 对 应 的 SQL b ua ^ 


DROP DATABASE maildb; 





CREATE DATABASE Mes 

USE maildb; 3 "ur 

CREATE TABLE m. D (Cserial` NOT NULL AUTO INCREMENT, 
"name? VARCHAR (50) NO' LL, 'email' VARC RS e PRIMARY KEY (^serial')) 


ENGINE - pO 
INSERT IN Menenius 
vues, ,| 
CERE ,'alGyaho.coom'), 


('Bijj', 'lil8stories.com'), 
(A83), 'x18126.com'), 
('dLfli' , 'zadégoogle.com'), 
(' 泰 勒 ', 'tleems.com'), 
(' 雅 雅 ','yya@edu.com')， 
亚 胡 '，, 'huya@citiz.net'); 
(D 研究 这 些 命令 ， 理 解 其 操作 。 
@ 观察 文件 夹 MySQL data 中 的 变化 。 
(2) 创建 下 面 的 命令 解释 脚本 ， 将 其 放 在 一 个 名 为 browser_mysql.php 的 文件 中 ， 相 应 地 
修改 用 户 ID 和 密码 , 然后 将 其 上 载 到 PHP 服务 器 上 , 放 在 合适 的 目录 下 , 以 用 于 Web 访问 。 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
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<form method="post" action="browser mysql.php"> 
<br>name: <br><input type="text" name="name" value="<?php echo $name?>" 


ex 


/><br> 
Xbr»email address «br»«input type="text" name-"email" value-"«?php 
echo $email ?>" /»«br» 
Xbr»«input type -"submit" name-"left" value-"«"» 
<input type -"submit" name-"right" value-"»"» 
<input type -"submit" name-"search" value=" 查 询 "><br> 
Xbr»«input type -"submit" name-"add" value=" 添 加 "> 
<input type -"submit" name-"update" value=" 更 新 "> 
<input type -"submit" name-"delete" value=" 删 除 "> 


<input type ="hidden" name="id" value= "«?php echo $id ?>" > 
<?php echo "<br \><br \>$message"; ?> 


</form> K 
</body> 
</html> = aS 
Q) 研究 这 段 肢 本， 以 理解 其 操作 。 y% 

© dnt esti 
© 导航 按钮 < >) 执行 查询 如 何 ySQL 自动 为 其 赋予 行 ID. 

© 查询 结果 是 如 何 排序 的 。、、 " 

(4) 在 Web 浏览 器 上 浏览 这 段 代码 的 执行 结果 ( 屏 间 截图 表 示 并 予以 说 明 )， 
O 运行 丢 本， 查询 通信 守 内 的 信息 ， 同 时 添加 EA E 


| XN 


"4862 改写 项 目 6-1 
5 
项 目 目标 ， 一人 x 
使 用 MySQLi 扩 展 的 面向 过 程 的 方法 改写 项 目 6-1， 文 件 名 为 browser_mysali_p php。 


项 目 6-3 改写 项 目 6-1 


项 目 目标 : 
使 用 MySQLi 扩展 的 面向 对 象 的 方法 改写 项 目 6-1， 文 件 名 为 browser_mysqli_o.php。 




















项 目 6-4 改进 本 章 案 例 中 的 聊天 室 
项 目 目标 : 

(D 可 以 加 入 图 片 方式 的 表情 等 。 

O 聊天 内 容 监控 聊天 室 的 管理 员 界 面 ， 对 不 合 主题 的 聊天 内 容 进行 删除 ， 并 对 的 
乱 的 网 友 取消 其 权限 。 为 此 也 要 建立 聊天 会 员 制 或 聊天 群 制 。 





网 上 购书 与 PHP 面向 对 象 技术 


通过 本 章 的 学 习 ， 能 够 使 读者 : \ 
(1) 理解 PHP 支持 的 面向 对 象 技术 。 \ 
(2) 掌握 在 PHP 中 使 用 面向 对 象 的 方法 。 NI- 
(3) 了 解 在 PHP 中 使 用 MVC 的 方法 。 


本 章 为 读者 准备 了 以 下 学 习 资源 : / 

(1) 示范 案例 : 展示 “网 上 购书 模块 ”的 分 析 、 设 计 与 实现 过 程 ， 对 应 本 章 的 7.1~7.3 节 。 
案例 代码 存放 在 文件 夹 “ 教 学 资源 \wuya\bookshop\”， 以 及 \wuya\left_num.php,main.php 中 。 

(2) 技术 要 点 : 描述 “PHP 面向 对 象 技 术 ” 的 技术 要 点 ， 对 应 本 章 的 7.4 节 。 其 中 的 示 
例 给 出 了 相关 技术 的 说 明 实例 ， 代 码 存放 在 文件 夹 “ 教 学 资源 \extendvch7\” 中 。 

(3) 实验 项 目 : 要 求 参考 示范 案例 对 网 上 书店 的 管理 员 模块 的 实现 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 : 

(1) 解读 示范 案例 的 分 析 和 设计 。 

(2) 模仿 练习 : 选择 一 个 PHP 开发 工具 ， 如 Dreamweaver， 按 照 实现 步骤 重 现 案例 。 

(3) 创作 练习 : 按 实践 项 目的 要 求 ， 先 做 出 分 析 和 设计 ， 再 在 PHP 开发 环境 中 实现 所 
做 的 设计 ， 提 升 对 PHP 面向 对 象 技术 的 理解 和 应 用 能 力 。 

学 习 过 程 中 ， 提 倡 结对 或 3 人 组 成 学 习 小 组 ， 采 取 分 工 合作 ， 交 流 设计 和 制作 的 经 验 
体会 ， 也 能 培养 协作 精神 ， 会 得 到 更 多 的 收获 。 
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本 章 案例 实现 的 是 本 书 案例 的 网 上 购书 模块 。 该 模块 搭建 一 个 规模 虽 小 ， 但 功能 齐全 
的 网 上 购书 模型 ， 分 一 般 用 户 和 管理 员 两 级 用 户 ， 分 别 实现 了 图 书 搜索 、 图 书信 息 显示 、 
购物 车 管理 、 订 单 生成 的 一 般 用 户 购书 功能 和 图 书信 息 、 图 书 类 别 、 订 单 的 信息 管理 功能 ， 
其 中 涉及 PHP 面向 对 象 技术 。 


7.1 网 上 购书 系统 分 析 






































随 着 互联 网 的 高 速 发 展 ， 人 们 生活 和 商品 销售 的 方式 也 发 耶 很 大 的 变化 。 网 上 购物 
是 由 互联 网 产生 的 一 种 新 型 消费 模式 ， 也 是 网 站 实现 赢利 的 os 更 是 电子 商务 发 展 
的 主要 方向 之 一 。 会 员 通过 网 络 购物 ， 足 不 出 户 地 就 可 jin cas. PHP 作为 





当前 日 益 推广 的 服务 器 脚本 语言 ， 对 于 电子 商务 的 不 遗 余力 的 。 使 用 PHP 和 
MySQL 数据 库 , 再 加 上 一 些 基 本 的 网 页 设计 技巧 :我们 可 以 很 轻松 地 搭建 一 个 网 上 购物 网 














站 ， 实 现 网 上 购物 的 各 种 功能 。 D 物 网 站 中 ， 它 涉及 的 技术 是 多 方面 的 ， 
而 且 需 要 考虑 大 量 的 设计 细节 。 di. 网 上 购书 的 工作 流程 ， 并 分 解 出 各 个 功能 
模块 以 便 设 计 和 实现 。 二 

SN X5. 


Sane >? fg ~ du 
744 系统 工作 流程 分 析 S x 
X 


LERIA B 1 ESAE AES o A REA NSE 
其 购书 流程 如 E 管理 员 在 后 台 对 系统 进行 管理 和 维护 , 其 工作 流程 如 图 7.2 所 示 。 








i Web 服务 器 


数据 库 服务 器 





7.1 一 般 用户 购 书 流程 
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S un 
O 用 户 向 服务 器 发 出 浏览 或 搜索 图 书 请 求 
© 服务 器 读 取 相 关 图 书信 息 ， 向 客户 端 返回 图 书信 息 。 
图 用 户 选 购 图 书 ， 暂 时 存放 在 购物 车 上 . 
© 用 户 进一步 确认 购物 车 上 的 图 书 ， 下 订单 。 
© 服务 器 验证 用 户 是 否 登 录 ， 确 认 用 户 信息 。 
用 户 填 写 订单 相关 信息 ， 确 认 订 单 。 
© 用 户 可 查询 订单 。 






次 
d. V 


(D 管理 员 向 服务 器 发 出 登录 请 求 . 
© 服务 器 向 管理 员 传送 欢迎 页 面 ， 并 提供 功能 选择 链接 .。 


Je — —3À 
数据 库 服务 器 


© 管理 员 可 对 图 书信 息 、 图 书 列表 进行 增删 编辑 ， 并 把 结果 存储 到 数据 库 中 . 
图 管理 员 可 对 图 书信 息 设置 推荐 和 热 销 属性 ， 并 把 结果 存储 到 数据 库 中 。 


© 管理 员 对 用 户 提交 的 订单 进行 汇总 、 查 询 和 管理 . 
7.1.2 系统 功能 模块 分 析 








通过 对 系统 工作 流程 的 分 析 ， 可 把 系统 分 为 前 台 和 后 台 。 前 台面 向 一 般 


要 功能 模块 。 
l. 系统 前 台 


() 图 书 显示 模块 : 显示 新 图 书 列表 、 分 类 图 书 列表 、 搜 索 
D 购物 车 模块 : 订购 图 书 、 查 看 和 管理 订购 图 书 、 下 订单 
(3) 订单 模块 : 检查 是 否 登录 ， 查 询 我 的 订单 。 





























图 














书 列表 和 详细 图 











户 ， 实 现 与 





© 
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2. 系统 后 台 


(1) 图 书信 息 管理 模块 : 添加、 编辑 和 删除 图 书信 息 。 
(2) 图 书 类 别管 理 模块 ， 添 加、 编辑 和 删除 图 书 类 别 ， 设 置 前 台 图 书目 录 查 询 列表 。 
G) 图 书 属 性 管理 模块 : 设置 图 书 的 推荐 、 热 销 属性 。 
(4) 订单 管理 模块 : 管理 用 户 提 交 的 订单 ， 查 询 订单 ， 汇 总 订单 。 
后 台 管理 中 各 模块 的 功能 较为 单一 且 独 立 , 主要 涉及 读 取 数 据 库 相 关内 容 和 表单 处 理 。 
但 要 认识 前 台 各 模块 的 功能 ， 需 要 进一步 分 析 各 模块 的 工作 流程 。 
3. 图书 显 示 模 块 
图 书 显示 模块 的 工作 流程 如 图 7.3 所 示 。 
A 二 LE 
UTE = 
Wo 服 效 器 
QN 


































Lan Y, X 
O 用 户 向 服务 器 发 出 ik. NK 
© 服务 器 向 用 户 传送 图 书 显示 页 面 ， 其 中 设 ASE MALA s ktn 
@ 在 详细 浏览 页 面 申 用 户 可 发 表 对 图 书 的 评价 等 反馈 ， 并 把 结果 存储 到 数据 库 中 。 
4. jh ^ 
购物 车 模块 的 工作 流程 如 图 7.4 所 示 。 








Web 服务 器 








pps bf Eseptieoeno L 


Ue i 
WV un 


O 用 户 从 图 书 显示 页 面 选 定 图 书 ， 向 服务 器 发 出 加 入 购物 车 请 求 。 

© 服务 器 处 理 了 添加 后 ， 用 户 的 去 向 可 能 是 继续 购书 ， 那 就 回 到 显示 页 面 ， 也 可 能 想 查看 购物 车 ， 
那 就 进入 查看 购物 车 页 面 。 

© 进入 查看 购物 车 页 面 后， 会 员 能 浏览 到 所 选 图 书 的 信息 ， 同 时 还 能 修改 购书 信息 ， 也 能 选择 继续 
购书 ， 或 下 订单 ， 还 可 能 清除 购物 车 。 

图 如 果 在 这 里 未 清除 购物 车 ， 就 在 购物 结束 时 自动 清除 。 


5. 订单 模块 
订单 模块 的 工作 流程 如 图 7.5 所 示 。 












7.5 ”订单 模块 的 工作 流程 


Sun 


(D 用 户 在 查看 购物 车 页 面向 服务 器 发 出 下 订单 请 求 。 

Q 服务 器 检查 用 户 是 否 登 录 ， 若 没有 登录 ， 则 转向 用 户 登 录 ， 向 用 户 登 录 / 注 册 模 块 ; 若 已 经 登录 ， 
则 传送 订单 确认 页 面 . 

© 在 订单 确认 页 面 中 ， 服 务 器 向 表单 显示 用 户 信息 及 付款 方式 ， 由 用 户 修改 或 选择 ， 同 时 提供 放弃 
购书 的 选择 。 

© 当 用 户 完成 购书 时 ， 生 成 订单 并 自动 清空 购物 车 。 

© 根据 付款 方式 显示 相应 信息 ， 当 选择 购书 卡 方式 时 ， 服 务 器 传送 购物 卡 结算 页 面 ， 即 修改 购书 卡 

© 订单 查询 作为 一 个 独立 的 模块 通过 主页 菜单 链接 ， 实 现 用 户 个 人 订单 查询 ， 没 有 登录 的 用 户 一 定 
没有 订单 信息 。 
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7.2 ”网 上 购书 系统 设计 


7.2.1 模块 的 逻辑 结构 设计 
根据 对 网 上 购书 模块 的 功能 描述 ， 可 得 各 个 子 模块 的 逻辑 结构 图 。 
(1) 图 书 显示 模块 的 逻辑 结构 如 图 7.6 所 示 。 
图 书 详细 电 朱 book_fullinfo.php 


规划 好 IDE zs UL tii CE REED. 
链接 与 按钮 


加 入 购物 不 处 理 chat_add.php 用 户 评价 肥 锁 处 理 user_fback.php 
图 7.6 图 书 显 示 模 块 的 逻辑 结构 
Q) 购物 车 模块 的 逻辑 结构 如 图 7.7 所 示 5 


加 入 购物 不 页 血 chat_add.php || 查看 购物 车 chat_check.php 修改 购书 处 理 chat_update.php 
反馈 信息 Mog E Mx PB 
控制 转向 站 特制 转向 MC etum wg qc ur 

























WEE Ur fi book. show.php 


订单 确认 页面 book_order.php 


F i] "book. check.php 













放弃 处 再 order_p.php 删除 购物 不 中 的 所 有 图 书 
7.7 ”购物 车 模块 的 逻辑 结构 
(3) 订单 处 理 模 块 的 逻辑 结构 如 图 7.8 所 示 。 






































登录 检查 order_check.php H 订单 确认 页 面 book_orderphp 购书 完成 exitphp 
控制 流程 转向 表单 : 用 户 信息 /付款 方式 等 提示 信息 
— d 4 ——— — í 提示 信息 

登录 /注册 模块 /register/regindex.php 订单 生成 ” 清空 购物 不 








order_p.php “| 一 | 订单 详细 信息 


主页 index.php | | 订单 查询 | | 购书 计 单 列表 H orderphp 
链接 order_search.php order_list.php 












































图 7.8 ”订单 处 理 模块 的 逻辑 结构 
(4) 后 台 管 理 模块 的 逻辑 结构 如 图 7.9 所 示 。 
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图 书 管理 book_admin.php 










3 添加 lbookadd.php 
| 1555 fit bookedit.php 


登录 losin.phl m" y $ 


届 性 添加 proadd.php 
届 性 编辑 proedit.php 
届 性 删除 prodel.php 














图 书 类 别管 理 class_admin.php 


















妇 钮 或 链接 


类 别 添加 Iclassadd.php 
类 别 编 纤 classedit,php 
类 别 删除 classdel.php 
订单 管理 orders_admin.php 订单 在 询 ordersck.php 
订单 汇总 ordertal.php 











图 7.9 后 台 管理 模块 的 逻辑 结构 


7.22 ”数据 库 设计 





通过 对 系统 的 分 析 ， 在 MySQL 数据 库 服 务 器 下 创建 名 为 bookshop 的 数据 库 ， 并 在 其 


中 建立 数据 库 表 ， 如 表 7.1 一 表 7.11 所 示 。 
表 7.1 图 书 子 类 信息 表 book_class 


字段 名 称 


book type. id 


字段 名 称 
book type id 





book type name 








字段 名 称 备 注 











人 DURER 





ü x 








hot. id | io auto increment 


热 销 图 书 序 列 号 









book id | intl2) 


图 书 序列 号 





hot order 









字段 名 称 | 类 型 (长 度 ) 








热 销 图 书 顺序 








jd g 





recom id int(3) | 





推荐 图 书 序列 号 





book id int(12) 





图 书 序列 号 





recom_order | int(3) 




















推荐 图 书 顺序 
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表 7.5 新 图 书信 息 表 book new 



















字段 名 称 | 类 型 (长 度 ) 描 g 























































































newid | intG) auto_increment | 新 图 书 序列 号 
book id — [int12) | 图 书 序列 号 
new. order int(3) 图 书 顺序 
字段 名 称 | amm | 5| saa |a] & x [om s 
book id int(12) 是 auto increment. | 图 书 编号 
book no varchar(30) 图 书 ISBN 
book name varchar(40) 书 名 
author varchar(30) 作者 
publisher varchar(40) 出 版 社 
pub_date datetime 出 版 日 期 
price float 图 书 原价 
price_m float 图 书 会 员 价 
book 1 price float 图 书 折扣 价 
book_storenum | int(4) 前 库存 量 
book class id | int(5) 所 属 子 类 
book_index mediumtext 是 录 
book abstract | mediumtext 是 内 容 提要 
book level tinyint(1) 1-5 级 图 书评 级 
book level pic |. varchar(255) 匀 书 评级 图 
book pic varchar(255) 图 书 封面 图 
input_date datetime CURRENT. TIMESTAMP 入 库 日 期 
book bs varchar(4) 平装 精装 | 平装 图 书包 装 
book view int(10) Vi n 
R77 购物 车 信息 表 book cart 
字段 名 称 | 类 型 (长 度 ) & i Ho g 
cart id int(12) auto increment 
user id varchar(30) 
book id int(12) 图 书 序列 号 
cart session id | varchar(32) tH IP 生成 用 户 session 
buy num int(12) 购买 数量 
order id int(10) 0 一 未 生效 订单 序列 号 
cart_time timestamp CURRENT. TIMESTAMP 订购 时 间 
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表 7.8 订单 信息 表 order_info 















































字段 名 称 | 类 型 (长 度 ) & t d xh 
order id int(10) auto increment 订单 序列 号 
user_name char(30) 联系 人 姓名 
order_post varchar(10) 送 书 邮编 
order_addr varchar(255) P RAUM 
order phone varchar(20) 联系 电话 
order_mail varchar(30) 邮箱 地 世 
order_send tinyint(2) 与 表 order_send 关联 | 送 书 方式 








order_fmoney | tinyint(2) 与 表 order_fmoney XP 





X | 付款 方式 








order_num int(4) 


购书 总 册 数 











到 位 小 数 
0 一 未 处 理 ，1 一 已 处 


order money | float 





order. state tinyint(2) 








order. time timestamp 








order. note 








字段 名 称 & d 





CURRENT TIMESTAMP 


" 















jo x 











send id | tinyint(1) auto_increment 


送 书 方式 序列 号 









send_name | char(12) 


送 书 方式 













send_con char(255) 





表 7.11 付款 方式 信息 表 order_fmoney 





说 明 





























字段 名称 | 类 型 (长 度 ) | 是 E 为 空 | 默认 值 | 主 备 注 描述 
fmoney_id | tinyint(1) | auto_increment | 付款 方式 序列 号 
fmoney_name | char(12) | 付款 方式 
fmoney_con char(255) 说 明 





£ I \ 注 ”数据 表 order info 5 order send. order fmoney 中 的 数据 有 关联 。 
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7.2.3 ”数据 操作 类 设计 


把 对 数据 库 的 操作 定义 为 一 个 类 DBSQL, 实现 对 数据 库 的 连接 和 对 数据 表 的 一 些 基本 
操作 功能 。 同 时 参照 MVC 架构 ， 定 义 类 DBSQL 的 子 类 booktype 实现 折 和 县 菜单 处 理 ， 子 
Æ control 实现 对 数据 库 bookshop 中 各 类 数据 表 的 数据 访问 , 而 子 类 user 是 对 数据 库 member 
中 各 类 数据 表 的 数据 访问 。 类 display 实现 页 面 的 分 页 显示 功能 和 对 显示 字符 数量 的 控制 ， 
各 类 所 包含 的 属性 和 方法 如 图 7.10 所 示 。 













. construct() construotÜ 


GetDTdataset($D Tname.Sserach ) 

Getbookdata(SDTname.Sserach) tr 

GetControlList($dataset,$page=1) 1 age ium($data) 
eJumpBar(Sdata,Spage- 1.Surl) 


select) 

insert() 

update() 

delete() 
begintransaction() 
rollback() 


numb .tem(Sitemno) 
nem | item(Sitemno) 






e". View Controller， 模 块 一 视图 一 控制 器 ) 是 设计 Web 应 用 的 一 种 方法 。 其 优势 在 于 把 
业务 逻辑 、 数 据 访问 和 界面 表现 分 离开 来 。 这 样 的 3 层 结构 能 提高 开发 效率 ， 降 低 维护 成 本 ， 增 强 
系统 的 扩展 性 . 现在 PHP 的 MVC 框架 比较 多 , 主要 有 CokePHP、ZendFramework、Wact 等 . 图 7.11 






(1D) 使 用 控制 器 生成 数据 , 创 
建 HTML 数 据 发 回 用 户 。 
(3) 浏览 器 显示 HTML 。 
(G3) 浏览 器 允许 用 户 提供 表 
应 的 相关 视图 中 。 单 向 控制 器 提交 数据 。 





7.11 MVC 的 示意 图 
虽然 可 以 直接 使 用 ZendFramework+Smarty， 模 块 和 控制 器 采用 ZendFramework， 视 图 采用 
Smarty， 但 考虑 到 与 各 模块 的 衔接 ， 采 用 逐步 建构 的 方式 来 解析 MVC 架构 。 
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724 界面 设计 


本 章 案例 涉及 的 页 面 较 多 ， 但 总 体 上 可 为 4 类 : 以 表格 方式 组 织 的 信息 列表 ， 如 图 书 























显示 、 购 物 车 查询 和 表单 列表 等 ， 以 显示 操作 提示 或 反馈 信息 为 主 的 页 面 ， 如 下 订单 、 清 
空 购物 车 等 ， 以 表格 组 织 的 详细 信息 ， 如 图 书 详细 信息 、 订 单 详细 信息 等 ， 以 表单 组 织 








信息 收集 页 面 ， 如 确认 订单 、 查 询 订单 。 但 图 书 显示 和 查看 购物 车 页 面 











E 











4 表单 界面 不 同 。 











案例 中 的 样式 定义 在 bscss.css 中 。 


(1) 信息 列表 页 面 (book_show.php、cart_list.php、order_list.php): 





标题 行 (样式 : id="bt") 





分 页 信息 栏 (样式 ，class="tdI") 





输入 页 次 (文本 框 ( 按 钮 ) 





表格 (样式 : id-"tdl") 
列表 标题 行 (样式 : id="bb") 
列表 内 容 





分 页 状态 栏 





页 面 操作 反馈 和 提示 信息 (样式 ，id="bb") 
2) 操作 提示 或 反馈 页 面 (cart_add.php.cart check.php. order ch 
标题 行 (样式 : i 





="bt") 


操作 提示 或 反馈 信息 (样式 ，id="bb") 
按钮 


(3) 详细 信息 显示 页 面 (book_fullinfo.php、order.php): 


标题 行 (样式 id="bt") 









3 ="tdl"|"tdd"|"bb") 
返回 ( 超 链接 : Javascript:close()) 


Til 


eck.php. exit.php): 





LN 注 页 面 宽度 为 780px。 
(4) 信息 采集 的 表单 页 面 (book_orderphp、order_search.php): 








WC: id="bt") 





操作 提示 行 (样式 ，id="bb") 





表单 标签 (class="tdl") | 表单 





提交 按钮 





操作 提示 或 反馈 信息 (样式 : id-"bb") 





LN book order.php 的 页 面 结合 了 列表 显示 信息 和 表单 采集 信息 页 面 。 


页 面 如 下 : 
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W 
Ul 





标题 行 (样式 : id-"bt") 

的 购书 清单 ! (样式 : id="bb") 
共有 XX 本 书 (样式 : id-"tdl") 

表格 (样式 : id="td1") 

















标题 行 (样式 : id="bb") 
注意 ;在 填写 完 订单 后 ， 请 使 用 浏览 器 的 打印 功能 打印 出 订单 。( 样 式 : id-"tdl") 
XXX: 请 确认 你 的 配送 信息 ! (样式 : id="bb") 
表单 标签 (class="td1") | 表单 

送 货 方式 (样式 : id="bb") | 单 选 按钮 

送 货 方式 简介 : XX X X(class-"tdl") 

付款 方式 (样式 ，id="bb") | 单 选 按钮 

付款 方式 简介 : XX X X (class-"tdl") 























放弃 确定 (提交 按钮 ) 
操作 提示 或 反馈 企 
Lan 


主页 index.php 中 的 两 个 框架 页 leftFrame 和 mainFrame。 其 中 leftFrame 包含 的 浮动 框架 numeFrame 
页 left_nemu.php 实现 了 折 司 菜单 的 功能 thainFrame 主要 放置 图 书 购物 车 和 订单 等 内 容 。 





(样式 : id="bb") 


7.3， 网 上 购书 系统 的 实现 


(1). 确认 在 站 点 根 目录 已 建立 了 文件 夹 webshop。 

(2) 确认 在 webshop 下 建立 了 文件 来 css. 

(3) 确认 在 webshop 下 建立 了 文件 夹 images， 再 在 
若干 幅 图 书 封面 图 片 , YE images 下 新 建文 件 夹 level, 复 

(4) 确认 在 webshop 下 建立 了 文件 夹 include。 


这 CSS 编 码 


代码 文件 : bscss.css 


(1) 启动 Dreamweaver， 新 建 CSS 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


1 Gcharset "utf-8"; 
p /* CSS Document */ 
Hi tarpo { /* 定 义 整个 页 面 的 样式 */ 






下 新 建文 件 夹 bookpic， 复 制 准备 
准备 的 图 像 文 件 1star.gif~5star.gif。 





pS 
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width: 600px; 
padding:1; 
margin: 0 auto; 

} 

#bt { ”/* 定 义 标题 样 式 */ 
font-size: 18px; 
font-weight: bold; 
color: $399; 
height:40px; 
background-color: #FFC; 
vertical-align: middle; 
text-align: center; 
padding-top: 10px 

} 

“tdl { /定义 表单 样式 */ 
font-size: 12px; 
color: #F60; 
background-color: $FFC; 
margin: 0px; 
padding: 0px; 
border: 0px none #FFF; 

) 

.tdd {  /* 定 义 表单 样式 */ 
color: #399; 
font-size: l4px; 
line-height: 15053; 

) 

#bb { ”/* 定 义 反 馈 人 
color: $366; 
background-color: #FC6; 
border: thin solid #CCC; 


样式 */ 





font-size: 13px; 
line-height: 150$; 
} 
table ,form{ 
margin: Opx; 


padding: Opx; 


:link (color: #399;} 
sited {} 


a 

a:vi 

a:hover (color: £$F90;) 
a 

t 





:active (color: #099;} 
r (line-height: 150$;) 
hr { line-height: 100$;) 
body ( 

padding: 0px; 





Qo 
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margin-top: 2px; 
5 D 


(3) 把 文档 以 bscss.css 为 文件 名 保存 在 新 建 的 ess 文件 夹 下 。 


M PHP $% 8 


7.3.1 数据 操作 类 
首先 要 定义 一 组 与 数据 库 相 关 的 全 局 配 
1. 全 局 配置 变量 
代码 文件 : config.inc.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
Q) 单 击 “ 代 码 ” 标 切换 到 “代码 ”视图 ， 输 入 如 下 和 代码; 
«?php 
define ("DBHost","localhost"); 
define("DBUser","root"); 
define ("DBPassword",""); 


define ("DBName", "bookshop" X; 


?> 





量 ， 然 后 定义 如 图 7.10 所 示 的 各 个 类 。 








(3) 把 文档 以 config.inc.php 为 文件 名 保存 在 新 建 的 各 clude 文件 夹 中 。 
2， 数 据 库 连接 和 基本 操作 类 
代码 文件 ，db:inc.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 > 
(2) 单 击 “ 和 代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 





require once('config.inc.php'); 
/** 
功能 : 数据库 的 基础 操作 类 
A, 
class DBSQL1{ 
private $CONN-""; // 定 义 数 据 库 连接 变量 


J** 
* 功 能 :构造 函数 ， 连 接 数 据 库 
iy 


public function construct ($DBName) ( 
$con=mysqli connect (DBHost, DBUser, DBPassword, $DBName) ; 
if(mysqli connect errno($con))| // 检 查 数据 库 连接 
echo "连接 MySQL 失败 : " . mysqli connect error(); 
) 


mysqli query($con,"set names 'utf8'"); 
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$this-»CONN-$con; 
) 
J** 
* 功 能 ， 关闭 数据 库 
s 
public function closedb()( 
if ($this->CONN) { 
return mysqli_close ($this->CONN) ; E 


J** 
* 功 能 ， 数 据 库 查 询 函 数 
* 人 参数， $sql SQL 语句 








* 返 回 : 数组 或 FALSE 
S 
public function select ($sql) { 
if (empty ($sql)) return false;  //lü/& SOL 语句 为 空 ， 则 返回 FALSE 
if (empty ($this->CONN)) returnifalse; // 如 果 数 据 库 连接 为 空 
则 返回 FALSE 
$results-mysqli query($this-»CONN,S$sql); 
if((!$results)or(empty($results)))( // 如 果 查 询 结果 为 空 ， 
则 释放 结果 并 返回 FALSE 
return false; 
) 
$count-0; 
$data-array(); 
while($rowemysqli fetch array($results))( // 把 查询 结果 重组 成 一 个 二 
维 数组 
$data[$count]=$row; 
$counttt; 
) 
return $data; 
} 
J** 


* 功 能 :数据 插入 函数 

* 参 数 ，$sql SQL 语句 

* 返 回 : 0 或 新 插入 数据 的 ID 

*/ 
public function insert ($sql-"")( 
if(empty($sql)) return 0; // 如 果 SOL 语句 为 空 ， 则 返回 FALSE 
if (empty ($this->CONN)) return 0; // 如 果 连 接 为 ， 空 则 返回 FALSE 
$results-mysqli query($this->CONN, $sql); 
if(!$results) return 0; // 如 果 插 入 失败 ， 则 返回 0; 
否则 返回 当前 插入 数据 的 ID 

else return mysqli insert id($this->CONN); 
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J** 
* 功 能 : 数据 更 新 函数 
* 参 数 ，$sql SQL 语句 
* 返 回 : TRUEORFALSE 




















x 
public function update ($sql-"")( 
if (empty ($sql)) return false; // 如 果 SOL 语句 为 室 ， 则 返回 FALSE 
if (empty ($this->CONN)) return false; // 如 果 连 接 为 室 ， 则 返回 FRALSE 
$results-mysqli query ($this->CONN, $sql); 
if(!$results) return 0; // 如 果 插 入 失败 ， 则 返回 0， 否 则 返回 当前 插入 数据 的 ID 
else return 1; 
} 
/** 


* 功 能 ， 数 据 删除 函数 
* 参 数 ， $sql SOL 语句 
* 返 回 : TRUEORFALSE 











eA 
public function delete ($sql-"")( 
if(empty($sql)) return false;  //lüyR SOL 语句 为 室 ， 则 返回 FALSE 
if(empty($this-»CONN)):;return false; // 如 果 连 接 为 窄 ， 则 返回 FALSE 
$results=mysqli query ($this-»CONN,$sql); 
if(!Sresults) return 0; // 如 果 插 入 失败 ， 则 返回 0， 耕 则 返回 当前 插入 数据 的 ID 
else return 1; 
) 
J** 
* 功 能 ， 定 义 事务 
public function begintransaction()( 
mysqli query($this-»CONN, SETAUTOCOMMIT-0");  // 设 置 为 不 自动 提交 , MySQL 
默认 立即 执行 
mysqli query ($this-»CONN, "BEGIN") ; // 开 始 事务 定义 
) 
J** 
* 功 能 : PIR 
public function rollback()( 
mysqli query ($this-»CONN, "ROOLBACK"); 
) 
J** 
* 功 能 : 提交 执行 
Xy 


public function commit ()í( 
mysqli query($this-»CONN, "COMMIT") ; 





Q 6 3) 
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i 


(3) 把 文档 以 db.inc.php 为 文件 名 保存 在 include 文件 夹 中 。 


Urasa 


数据 操作 基本 类 DBSQL 中 用 于 连接 数据 库 并 对 其 中 的 数据 表 实 现 插入 、 更 新 、 删除 操作 和 事务 处 理 。 
事务 操作 是 在 执行 多 个 更 新 或 删除 操作 时 为 了 保证 数据 完整 性 而 使 用 的 。 
把 这 些 基本 操作 封装 在 一 个 类 中 能 增强 代码 的 可 读 性 、 系 统 的 扩展 性 和 健壮 性 。 
第 7 行 : 类 DBSQL 的 私有 属性 SCONN， 定 义 数据 库 连 接 变量 。 
第 11 一 18 行 : 构造 函数 _construct() 用 于 连接 数据 库 表 。 
第 22 一 26 行 : 函数 closedb() 用 于 关闭 数据 库 表 。 
第 32 一 46 行 : 函数 select($sql="") 用 于 执行 由 $sql 指定 的 SQL 语句 的 查询 操作 。 
第 52 一 58 íf: 函数 insert($sql="") 用 于 执行 由 $sql 指定 的 SQL 语句 的 插入 操作 。 
第 64 一 70 行 : 函数 update($sql="") 用 于 执行 由 $sql 指定 的 SQL 语 向 的 更 新 操作 ， 
第 76 一 82 åf: 函数 delete($sql="") 用 于 执行 由 $sql 指定 的 SQL 语 钉 的 删除 操作 。 
第 86 一 89 行 : 函数 begintransaction() 用 于 实现 事务 操作 的 起 始 功 能 . 
第 93 一 95 行 : 函数 rollbackO 用 于 实现 事务 操作 的 回 滚 功能 - 
第 99 一 102 行 : 函数 commit() 用 于 实现 事务 操作 的 提交 执行 功能 . 


3， 图 书 分 类 查询 菜单 子 类 
代码 文件 :booktype.inc.php SM. 


新 建 .PHP; 文 档 。 
切换 到 “代码 ”视图 ， 输 六 如 下 代码 。 

















(1) 启动 Dreamweaver 
(2) 单 击 “ 代 码 ” 标 
«?php 

require once ('db.inc.php'); E 
"n D. 











* 功 能 ; 实现 对 图 书 类 别 的 数据 处 理 1 
*/ N 
class booktype extends DBSQL{ 
public function __construct(){  // 加 载 父 类 构造 函数 ， 创 建 数据 库 连 接 
$DBName=DBName; 


parent:: construct ($DBName) ; 
) 
J** 
* 功 能 : 提取 图 书 类 列表 
* 返 回 : 数组 
SA 
public function GetBkTypeList () { 
$sql-"SELECT * FROM book type"; 
$b-Sthis-»select ($sql); 
return $b; 
) 
J** 


* 功 能 : 提取 图 书 分 类 列表 
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* 参 数 ， 图 书 类 别 
* 返 回 : 数组 
LA 
public function GetBkClassList ($search-1)( 
$sql-"SELECT * FROM book class WHERE book type id-'$search'"; 
$b-Sthis-»select ($sql); 
return $b; 


J** 
* 功 能 : 弹出 菜单 的 二 级 菜单 项 的 数目 
* 返 回 : 字符 串 
*/ 
public function numb item($itemno)( 
$bktclist-$this-»GetBkClassList ($itemno); 
$Sccount-count ($bktclist); 
return $ccount; 


/** 
* 功 能 ， 弹 出 
* 返 回 ， 字符 串 
sy 
public function nemu item(Sitemno)( 

en DT 
Sbktclist-$this-»GetBkClassList (Sitemno); 
$ccount-count(Sbktclist);  // 统 计 弹 出 菜单 的 二 级 菜单 项 的 数目 
for ($k-0;$k«$ccount; $k++) 

S$item.-"&nbsp;&nbsp;&nbsp;€a href-'webshop/book show.php?title =". 
Sbktclist[$k]['book class name']. "&&page-l&&search-book class id-". $bktclist 
[$k] ['book. class id']."' target-'mainFrame'»".$bktclist[$k]['book class 
name']."4/a»«br»"; 








return $item; 





(3) 把 文档 以 booktype.inc.php 为 文件 名 保存 在 新 建 的 include 文件 夹 中 。 


é3. 
DM eoe 


类 booktype 是 数据 操作 基本 类 DBSQL 的 子 类 ， 用 于 生成 left.php 中 的 分 类 显示 

第 6 行 : 类 booktype 是 DBSQL 的 子 类 (注意 关键 字 extends 的 作用 )。 

第 7 一 10 行 : 构造 函数 _construct() 用 于 加 载 父 类 构造 函数 ， 创 建 数 据 库 连 接 。 

第 15 一 19 £r: 函数 GetBkTypeList() 用 于 查询 数据 表 booktype 中 的 数据 ， 查 询 结果 重组 成 一 个 二 维 数 
组 返回 。 

第 25 一 29 fr: 函数 GetBkClassList(Ssearch=2) 用 于 查询 数据 表 bookclass 中 指定 book type id 的 数据 ， 
查询 结果 重组 成 一 个 二 维 数 组 返回 。 
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第 34 一 38 行 : 函 孝 numb_item(Sitemno) 用 于 统计 弹出 菜单 的 二 级 菜单 项 的 数目 。 
第 43 一 51 行 : 函数 nemu_item(Sitemno) 用 于 生成 菜单 的 二 级 菜单 项 
4. 获取 图 书 /订单 的 数据 子 类 





代码 文件 : control.inc.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 





«?php 
require once('db.inc.php'); 
/** 
*Xüe: 实现 对 数据 库 表 中 的 数据 提取 
* 
/ 


class control extends DBSOL( 
public $ pageSize; // 定 义 每 页 显示 的 记录 数 

public function control()(  // 加 载 父 类 构造 函数 ， 创 建 数 
$DBName=DBName; 





parent:: construct ($DBName); 
$this-» pageSize-8; 
) 
J** 
* 功 能 : 提取 指定 数据 表 符 合 条 件 的 记录 
* 参 数 ， 数 据 表 和 查询 条 件 
* 返 回 ， 数组 
x 
public function GetDTdataset ($DTname, $search)( 
Ssql-"SELECT * FROM $DTname WHERE ".$search; 
$data s-$this-»select($sq1); 
return $data s; 


J** 
* 功 能 : 提取 图 书信 息 
+ 参数 : 数据 表 和 查询 条 件 
* 返 回 ， 数 组 

in 





public function Getbookdata ($DTname, $search)( 
$data s-$this-»GetDTdataset ($DTname, $search); 
if(SDTname!-"book info")( 
$books-array(); 
for ($j=0;$j<count ($data s);$j++){ 
$sql="SELECT * FROM book info WHERE book id-".$data s[$j] 
['book id']; 
$book-Sthis-»select ($sql); 
if ($book! 





) Sbooks-array merge($books,Sbook) ; 


} 


return $books; 
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} 


else return $data s; 

















J** 
* 功 能 :分 页 提取 图 书 /订单 列表 
* 参 数 ， 当 前 页 码 
* 返 回 : 数组 

gi 


public function GetControlList ($dataset, $page=1) { 
$control_o=$dataset; 
$b-array(); 
if ($page<1) S$page-1; 
$control_num=count ($control_o); 
$pagelast-ceil($control num/$this-» pageSize); 
if ($pagelast«1) $pagelast-1; 
if ($page»Spagelast) $page-S$pagelast; 
$pagenum-$control num-(floor($control num/$this-» pageSize)* 
$this-» pageSize); 
if ($page<$pagelast || $pagenum--0) $pagenum-$this-» pageSize; 
$start-(Spage-1)*$this-» pageSize; 
if($start«$control num): S$bsarray slice($control o,$start,$pagenum); 
return $b; 


/x 
* 功 能 ， 从 $str 提取 指定 长 度 $num 的 
* 返 回 : 字符 串 

zy 





public function Getstr(S$str-z"",$num-20)( 
Sstr = trim(S$str); 
$strlength = strlen($str); 
if ($num == 0 || $num >= $strlength) ( 
return $str; // 若 截取 长 度 等 于 0 或 大 于 等 于 本 
返回 字符 串 本 身 





的 长 度 ， 









} 
elseif ($num < 0){ // 如 果 截 取 长 度 为 负数 ， 
$num = $strlength + $num; // 那 么 截取 长 有 
if (Snum < O)( 
$num = $strlength; // 如 果 截 取 长 度 的 绝对 值 大 于 字符 串 本 身长 
度 ， 则 截取 长 度 取 字 符 串 本 身 的 长 度 





中 长 度 减 去 截取 长 度 


) 

if (function exists('mb substr'))í 
$newstr = mb substr($str,0, $num); 

) 

elseif (function exists('iconv substr'))( 
$newstr = iconv substr($str,0, $num); 
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) 

else( 
//$newstr = trim right(substr($str, 0, $num)); 
$newstr = substr($str, 0, $num); 

) 

if ($str != $newstr) ( 
$newstr.— '...'; 

) 

return $newstr; 





(3) 把 文档 以 control.inc.php 为 文件 名 保存 在 新 建 的 include 文件 夹 中 。 


is 

(D) array_merge(array arrayl, array array2[, array …]) 合 并 两 个 或 多 个 数组 . 若 此 参数 中 有 相同 的 字符 串 
键 名 ， 则 该 键 名 的 值 取 后 面 参数 ， 若 数组 包含 数字 键 名 ， 则 后 面 套数 的 值 被 追加 在 末端 。 

Q) array. slice(array array, int offset[, int length]) 返回 根据 offset 参数 和 length 参数 所 指定 的 array 数组 
中 的 一 段 序 列 ， 若 offset 为 正 ， 则 序列 将 从 array 中 的 此 篇 移 量 开始 。 若 offset 为 负 ， 则 序列 将 从 array K 
端 向 前 |offset| 开 始 。 若 length 为 正 ， 则 序列 中 将 具有 jength 个 单元 。 若 length 为 负 ， 则 序列 将 终止 在 数组 
末端 前 |length| 处 。 若 省 略 length， 则 序列 从 offset. 开始 到 array 的 末端 。 


人 as 


子 类 control 用 于 获取 数 锯 并 分 离 出 指定 查询 表 中 指定 页 的 数据 ， 以 便 在 网 页 中 输 
第 7 行 : 子 类 control 的 公共 属性 $_pageSize,, 定义 每 页 显示 的 记录 数 ， 
第 8 一 12 行 : 构造 通 数 _construct() 除 了 加 载 父 类 的 构造 函数 实现 对 数据 库 的 连接 外 ， 还 初始 化 了 变 
量 $_pageSize. 
第 18 一 22 行 ; 方法 GetDTdataset(SDTname,$search) 用 于 获取 数据 表 $DTname 符合 条 件 Ssearch 的 数据 查 
询 集 ， 以 二 维 数组 形式 返回 。 
第 28 一 40 fr: 方法 Getbookdata(SDTname,Ssearch) 用 于 获取 数据 表 $DTname 符合 条 件 $search 的 图 书 
数据 查询 集 ， 以 二 维 数组 形式 返回 。 
第 46 一 59 行 : 方法 GetControlList(Sdataset,Spage-1)/0] FA 8 4:48 4k dataset 指定 页 面 Spage 中 的 数据 ， 
以 二 维 数组 形式 返回 。 
第 64 一 91 行 : 函数 Getstr($str="",Snum=20) 用 于 提取 字符 串 Sstr 中 前 Snum 个 有 效 字符 。 


5. 用 户 子 类 


代码 文件 ，userinc.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 











1 <?php 

2 require once('db.inc.php'); 
3 /** 

4 * 功 能 :实现 用 户 数据 的 操作 
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class user extends DBSQL( 
public function _ construct()( 
$DBName-"member"; 





(3) 把 文档 以 userinc.php 为 文件 名 保存 在 include 文件 夹 中 。 


M 


tg 
aeu 


子 类 user 用 于 对 数据 表 member 的 相关 操作 。 继承 父 类 中 的 定义 的 各 种 公共 属性 和 方法 
了 数据 库 的 名 称 member， 履 盖 了 原来 的 数据 库 bookshop. 


6， 数 据 显示 子 类 
代码 文件 ，display.inc.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
/x 
* 功 能 ， 实现 页 面 导航 栏 的 显示 
x) 
class display( 
public $-pageSize-10; 77 每 页 显示 数量 
private $ data; /7 要 分 页 的 数据 
priváte $ pageNum-1; // 总 页 数 
J** 
* 功 能 ， 构 造 函数 





* 参 数 ，$data 要 分 页 的 数据 ，$pageSize 每 页 显示 数量 
in 
public function — counstruct ($data,S$pagesize-8)( 
if(Spagesize»0) $this-» pageSize-S$pagesize; 
$this-» data-$data; 
$this-» pageNum-$this-»GetpageNum ($data) ; 
) 
J** 
* 功 能 ， 取 得 总 页 数 


public function GetpageNum ($data) { 
$data num=count ($data) ; 
$pagelast-ceil($data num/S$this-» pageSize); 





return $pagelast; 


parent:: construct($DBName);  // 加 载 父 类 构造 函数 ， 创 建 数据 库 连 接 


， 但 重新 指定 
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J** 
* 功 能 ， 生 成 分 页 导航 栏 
ea 
public function GetJumpBar ($data, $page=1, $url) { 
$count=count ($data) ; 
$pagelast=$this->GetpageNum ($data); 
$strJumpBar=""; 
if ($pagelast<1) $pagelast=1; 
if ($page>$pagelast) $page=$pagelast; 
$hr="<a href='".$url. ($pagelast)."'"; 
if ($count=: 





$pagelast-0; 
) 
else( 


$msg1=" 当 前 页 : 





".S$page; 


if ($page<>1) $strJumpBar.-"«a firef='",$url."1'> 第 1 页 </a> "; 





else $strJumpBar.=" 第 1 页 
$strJumpBar.-" | "; 
if($page»1) $strJumpBar.-"«a href-'".$url.($page-1)."'» Ł—7 


SB» us 
if(Spagec$pagelast) $strJumpBar.-"«a href-'".$url.(Spage*1)."'» 
下 一 页 </a> | "; 





if(Spage!-S$pagelast) $strJumpBar.="<a href='".$url. 
($page last)."'» 最 后 页 </a> w3 
else $strJumpBar.-" $k jaji"; 
) 


return array('JumpBar'-»5$strJumpBar, 'msg'-»$msgl); 





(3) 把 文档 以 display.inc.php 为 文件 名 保存 在 新 建 的 include 文件 夹 中 。 


Hl 


一 代码 解读 


类 display 用 于 根据 数据 设置 分 页 显示 的 导航 栏 . 

第 6 一 8 行 : 定义 类 display 的 公共 属性 $_pagesize 和 私有 属性 $_data，$_pageNum。 

第 13 一 17 行 : 构造 函数 _construct($data,$pagesize)， 初 始 化 类 display 的 公共 属性 ， 其 中 $_pageNum 
由 方法 GetpageNum($data,Spagesize) 指 定 

第 21 一 25 行 : 函数 GetpageNum($data) 用 于 计算 数据 集 Sdata 中 每 页 显示 $pagesize 行 的 最 大 页 数 。 

第 29 一 53 行 : 函数 GetJumpBar($data,Spage=1,$url) 用 于 生成 页 面 导航 栏 的 信息 。 
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7.3.2 图 书 查询 
lL 图 书 分 类 菜单 
代码 文件 :left_nemu.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ” 











视图 ， 输 入 如 下 代码 。 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 

<head> 





«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<title> 搜 索 图 书 </title> 
«link href="css/left.css" rel="stylesheet", type-"text/css" /> 
</head> 
<body> 
<div class="txt"> 
<?php 
$nume-""; 
Sitem-0; ”// 初 始 化 自 定义 变 基 
require once('webshop/include/booktype.inc.php'); 
$bktc-new booktype(); 
$bktlist-S$bktc-»GetBkTypeList(); 
$tcount-count ($bktlist); 
for($j-0;$j«$tcount;$j44) 
Si-Sbktlist[$j][0]; 
$tccount-$bktc-»numb item($i); 
if(Stcecount»0)( 
if(isset($ GET['item'])) $item=$_GET['item'];// 获 取 页 面 传递 的 数据 ， 
确定 是 否 有 子 菜单 





if(Sitem--$i && $item!=0){ 
$nume.-"&nbsp;«a href-'left nemu.php?item-0" 
target-' self'»-«/a» &nbsp;".$bktlist[$j] [1]."<br>"; 
$nume.-$bktc-»nemu item(Sitem); 
) 
else $nume.-"&nbsp;«a href-'left nemu.php?item-".$i."' 
target-' self' >+</a> &nbsp;".$bktlist[$j] [1] ."<br>"; 
$ 
else $nume.-"&nbsp; &nbsp; &nbsp; <a href='webshop/book show.php?title-". 
S$bktlist[$j][1]. "&&page-l&&search-'book type id-".$bktlist[$j] [0]."" 
target- 'mainFrame'»".$bktlist[$j] [1]."«/a» <br>"; 
) 
echo $nume; 
Sbktc-»closedb(); 
2> 





</div> 


0 
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35 </body> 
EE </html> 


(3) 把 文档 以 left_nemu.php 为 文件 名 保存 在 站 点 根 文件 夹 下 。 


全 


left nemu.php 实现 了 分 类 查询 菜单 的 显示 功能 ， 通 过 超 链接 折 司 和 展开 二 级 子 菜单 。 
第 12 一 13 行 : 初始 化 变量 。S$nume 记录 显示 其 余 的 内 容 ，Sitem 取 非 负 整数 数值 . 
第 14 一 16 行 : 包含 所 有 需要 的 文件 ， 即 图 书 类 别 子 类 booktype.inc.php， 注 意 存放 这 些 文件 的 路 径 。 
第 15 行 : 创建 对 象 实例 Sbktc。 
第 16 行 : 调用 子 类 booktype 中 的 方法 GetBkTypeListO 函 数 ， 获 取 图 书 类 别 列表 。 
第 17 行 : 统计 图 书 类 别 的 个 数 
第 18 一 30 行 : 生成 图 书 类 别 查询 菜单 。 其 中 
第 19 行 : 获取 图 书 类 别 的 序列 号 。 
$ 204r: 统计 该 图 书 类 别 所 包含 的 图 书 子 类 数目 。 
第 21 一 28 行 : 含有 子 类 的 处 理 ， 即 变量 Sitem 作为 设置 图 书 类 别名 称 前 超 链接 + 或 -的 “开关 "。 其 中 
第 22 行 : 如 果 单 击 + 或 - 超 链接 符号 后 ， 则 进入 本 页 会 通过 GET 方式 获取 item 的 值 。 
第 23 一 26 行 : 当 $item 为 非 零 值 时 的 处 理 ,其 中 
第 24 行 : 把 在 图 书 类 别名 称 前 含 超 链接 -( 传 递 Sitem 为 零 ) 的 字符 串 作 为 菜单 信息 的 部 分 内 容 。 
第 25 行 : 把 该 类 别 图 书 的 二 级 子 荣 单 设置 为 菜单 信息 接 下 来 的 内 容 。 
第 27 行 : 当 $item 为 零 时 ,， 拆 登 二 级 子 菜单 并 在 图 书 类 别 洛 称 前 设置 起 链接 +( 传 递 Sitem 为 当前 
图 书 类 别 序列 号 )。 
第 29 行 : 不 含有 子 类 的 处 理 》 X3 
第 31 行 : 显示 设置 的 菜单 信息 . 
2. 图 书 搜索 处 理 
代码 文件 ;Search_keyphp 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
«?php 
$search-1; 
$keys-(string)$ POST['keys']; $cond-$ POST['seltl']; 


if($cond--"pub date")( 
$search-" $cond»-$27$keys$27"; 











信息 为 带 有 超 链 接 的 图 书 类 别 的 名 称 。 


elset 
$search-" $cond like $27$keys$27"; 
) 


echo "«meta http-equiv-'Refresh' content-'0;url-webshop/book show.php? 
title-$title&search -$search&pp-l&page-'»"; 
?» 


(3) 把 文档 以 search. key.php 为 文件 名 保存 在 站 点 根 文 件 夹 下 。 
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PR 
search key.php 是 对 left.php 页 面 中 的 表单 处 理 程序 ， 主 要 实现 了 对 数据 的 获取 和 传递 。 这 里 使 用 的 
URL 编码 : %27 是 对 单 引号 ' 的 编码 
第 2 行 : 初始 化 变量 $search. 
第 3 行 : 获取 表单 数据 ，$_POST['selt1"] 是 列表 域 中 选中 的 选项 ，$_POST['keys"] 是 文本 输入 域 中 输入 
的 内 容 ， 注 意 对 这 个 数据 使 用 了 强制 类 型 转换 (string). 
第 4 一 6 行 : 对 出 版 日 期 这 类 特殊 数据 进行 处 理 , 找 出 的 是 大 于 某 天 的 ,而 其 他 条 件 是 匹配 的 字符 串 。 
第 10 行 : 页 面 重新 定向 到 webshop/book_show.php， 同 时 传递 相关 数据 。 


3， 特 色 栏目 链接 处 理 
代码 文件 ，top.php、main.php 


(1) 在 Dreamweaver 中 ， 打 开 文 件 top.php。 
(2) 切换 到 “代码 ”视图 ， 添 加 第 10~12 行 的 代码 并 修改 第 52 行 的 代码 ， 如 下 所 示 。 


<div id="vai2" align="center"> 
«a href=" 









target="mainFrame"> 热 灾 图 书 </a>&nbsp; | & 
<a href="W k st E E 
target="mainFrame"> 特 价 图 书 </a>&nbsp; | &nbsp; 


推荐 图 书 &&DTr 


BTENU target- "mainFrame"»jftfr|d-5«/a»&nbsp; | &nbsp; 





target-"mainFrame"» 最 新 图 书 </a> 





(3) 保存 文件 4 
(4) 在 Dreamweaver 中 ， 打 开 文件 main.php。 
(5) 切换 到 “代码 ”视图 ， 修 改 main.php 中 “更 多 ” 


(D 3 qp: 








HEB “H” XU: 


p? 













(6) 保存 文 件 。 

733 ”图 书 显示 处 理 

1， 图 书 显示 列表 

代码 文件 ，book_showphp 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
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«?php 
require once('include/control.inc.php'); 
require once('include/display.inc.php'); // 请 求 包含 相反 
$title=" 图 书 显示 "; 
$search=1; $page-1; $pp=0; 
$DTname="book info"; 





if (isset ($_GET['title'])) Stitle-$ GET['title']; // 获 取 由 URL 传递 来 的 数据 
if(isset($ GET['DTname'])) SDTname-$ GET['DTname']; 

if(isset($ GET['search'])) $search-$ GET['search']; 

if(isset($ GET['page'])) S$page-$ GET['page']; 

if(isset($ POST['page'])) Spage-$ POST['page']; 

if(isset($ GET['pp'])) S$pp-$ GET['pp']; 


if($page«1) $page-1; 
$books-new control(); 
$book s-$books-»Getbookdata ($DTname,$search); XW/ 获 取 要 显示 图 书 的 数据 








$title=" 图 书 搜索 "; 





$search-str replace("'", "$27",$search); // 把 ' 替 代为 "%27 
$ss-"?title-$title&&DTname-$DTname&&Search-$search&&pp-1l&&page-"; 


) 

else( 
$ss-"?title-Stitle&&DTname-SDTname&&search-$search&&page-"; 

) 

$url="book show.php".$ss; 

$displaybook-new display ($book_s, $books-> pageSize); 





$displaybook-» pageSize-$books-» pageSize; // 统 一 显示 页 与 数据 分 页 的 行 数 
$pagelast-$displaybook-»GetpageNum(Sbook s); // 提 取 显 示 的 最 后 页 码 
$book-$books-»GetControlList($book s,$page); // 提 取 当 前 页 的 显示 数据 
$displaybar=$displaybook->GetJurmpBar ($book_s, $page, $url); // 生 成 分 页 导航 术 
2» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«head» 





«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8"» 
<tit1le> 疼 书 显示 </tit1le> 


"mainFrame" /> 





<base targe 
«link href- 
</head> 
<body> 
<div id="appb"> 
«div id-"bt"»i 





css/bscss.css" rel-"stylesheet" type-"text/css" /» 





EHJ&mdash; &mdash;«?php echo $title; ?»«hr/»«/div» 
<form action-"«?php echo $url. (S$page);?»" method="post" target-" self"? 
«table width-"600" border-"0" cellspacing-"0" class-"tdl"» 

<tr><td> 共 有 <?php echo count($book s); ?> 本 书 &nbsp; gnbsp; 共 <?php echo 
$pagelast; ?> 页 &nbsp;&nbsp;<?php echo $displaybar['JumpBar']; ?></td> 
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«td align="right"> 输 入 页 次 : «input type="text" size="3" name="page"> 
«input type-"submit" name-"send2" value=" 转 到 " /></td></tr> 
</table> 
</form> 
«table width-"600" border-"1" cellspacing-"1" class-"tdl"» 
<form name-"frm" action-"cart add.php«?php echo $ss;?»" method-"post"» 
«tr align="center" id-"bb"»«td width="30"> 选 中 </td><td width="200"> 
书 名 </td> 
«td width="150"> 作 者 </td><td width="60"> 出 版 社 </td><td width="30"> 原 





价 </td> 

«td width="30"> 折 扣 </td><td width="60"> 购 买 数量 </td><td width="40"> 
详情 </td></tr> 
<?php 


$buynum-array(); 
for ($j=0;$j<count ($book) ;$j++) { ”// 按 行 依次 输出 图 书信 息 
$buynum[$book[$j] ['book id']]=0; 
echo "<tr class-'tdl'»"; 
echo "«td align-'center' width-'50'»«input type-'checkbox' name-'bookbm 
[".$book[$j] ['book id'] ."]' value-'sel'»".$book[$j] ['book id']."«/td»"; 
echo"«td width-'200'»".S$books-»Getstr($book[$j] ['book name'],18) 
"«/td»"; 
echo"«td  width-'150'2",.S$books-»Getstr($book[$j] ['author'],10). 
"«/td»"; 
echo"«td»".$book[$3]['publisher'],"«/td»«td»"; 
printf("$.2f£",$book[$j] ['price']); 
echo"«/td»«td»"; 
printf("$.2f",$book[$j] ['book. 1. price']); 
echo'&/td»«td align-"center"5«input type="text" size-"4" name-"buynum 


['.Sbook[$3] ['book id'].']" »4/ta»5'; 
echo"«td align-'center'»«a href-'book fullinfo.php?bookid-".$book 
[$j1['book id']."' target-' blank' > 详情 ..</a></td></tr>"; 


) 
if (count ($book)<$books-> pageSize)( 
Visi tete 
echo"«td align-'center' colspan-'8' height-'". (abs($books-» pageSize- 
count ($book) ) *27) ."'» &nbsp;«/td»«/tr»"; 
) 


?» 


echo"«tr clas 








<tr><td colspan= 
</td></tr> 
<tr id="bb"><td align="left" colspan="5"> 提 示 : 先 选 中 购买 的 书 ， 再 填写 购 
买 的 数量 ， 最 后 单 击 “ 放 入 购物 车 ”按钮 </td> 
«td colspan-"3" align="center"><input type-"submit"value-"jf A 
购物 车 "/></td></tr> 
</form> 
</table> 


align="right"><?php echo $displaybar['msg'];?> 
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«/div» 
</body> 
</html> 


(3) 把 文档 以 book_show.php 为 文件 名 保存 在 webshop 文件 夹 下 。 


hran 


book show.php 实现 对 查询 图 书 的 显示 功能 。 查 询 的 方式 可 以 是 表单 提交 的 关键 字 搜索 ， 也 可 以 是 分 
类 查询 中 的 菜单 链接 ， 还 可 以 是 导航 菜单 中 的 特色 书目 的 链接 。 采 用 显示 分 页 技术 ， 传 递 数 据 的 方式 是 
URL， 包 括 4 个 参数 : title 页 面 中 显示 的 标题 ; page 当前 显示 页 码 ; DTname 操作 的 数据 库 表 ; search 数据 
查询 条 件 。 
第 4 一 13 行 : 获取 并 处 理 查询 图 书 的 URL 参数 。 而 pp=1 对 应 来 自 文 本 输出 查询 的 title 和 search. 
第 1447: 创建 control 类 的 对 象 。 
第 15 行 : 对 象 获取 要 显示 图 书 的 数据 集 ( 二 维 数 组 )。 
第 16 一 24 行 : 准备 display 类 中 的 URL 套数 。 
第 25 行 : 创建 display 类 的 对 象 . 
第 27 一 29 fr: 生成 翻 页 导航 栏 
第 42 行 : 显示 页 面 的 标题 。 
第 43 一 48 行 : 设置 翻 页 导航 栏 及 状 让 包含 一 个 输入 页 码 转向 的 表单 ， 处 理 程序 是 自身 。 
第 50 一 77 行 : 表单 中 包含 用 户 选 择 图 书 的 操作 方式 。 一 是 在 第 1 列 设置 选中 复 选 框 ， 二 是 在 第 6 列 
设置 文本 输入 购买 的 数 量 ; 下 方 设置 提交 按钮 ”处 理 程序 为 cart_add.php， 注 意 到 添加 
后 用 户 可 能 还 会 继续 购书 ， 因 此 要 把 参数 待 递 过 去 。 其 中 
第 56 一 72 行 : 按 行 显示 当前 页 的 图 书 数据 。 
$ 744p: 输出 状态 行 ， 
第 75 行 : 显示 操作 提示 信息 。 


2， 显 示 图 书 详 细 信息 


代码 文件 : book_fullinfo.php 








.和 分 页 显示 的 吉 据 、 








(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

O 单 击 “代码” 标签， 切换 到 “代码 ”视图 ， 输 入 如 下 代码 。 

<?php 
require once('include/control.inc.php'); // 请 求 包 含 相应 类 的 文件 
$bookid=1; $msg=""; $num=0; $level=0; 
if(isset($ GET['bookid'])) $bookid=$_GET['bookid']; // 获 取 图 书 序列 号 bookid 
$book s-new control(); // 创 建 图 书 对 象 
$sql="SELECT * FROM book info WHERE book id=".$bookid; 
$book-$book s-»select($sql); // 使 用 基本 操作 类 中 的 方法 select ($sq1) 查询 数据 集 
$user-new control(); // 创 建 反 馈 用 户 对 象 
$sql2="SELECT * FROM ueser message WHERE book id-".S$bookid; 
Susermsg-$user-»select ($sg12); 
if ($usermsg=="") $msg=" 暂 无 评价 信息 "; 
else $num=count ($usermsg); 
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?» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 图 书 详细 信息 显示 </title> 
<link href="css/bscss.css" rel="stylesheet" type="text/css"/> 
</head> 
<body> 

















<div id="appb"> 
«div id="bt"> 查 询 的 图 书 详细 信息 <hr/></div> 
<table width="100%" border="0" cellspacing="0"> 
<tr><td id-"bb"»&nbsp; &nbsp; </td></tr> 
</table> 
<table width="100%" border="1" cellspacings"1l" class="tdl"> 
<tr><td width-"10$" align="right"> B4 4/td> 
«td width-"50$"  class-"tdd"»«?php echo $book[0] ['book 
name']; ?></td> 
«td rowspan="9" align="center" ><img sr 
pic]. 9»" x </td></tr> 
<tr><td align="right”> 作 者 </td> 
<td class-"tdd"»«?php echo $book[0]['author']; ?></td></tr> 
<tr><td alig right"> 出 版 社 </td> 
«td class="tdd"><?php echo $book[0]['publisher']; ?>&nbsp; 出 版 社 
</td></tr> 
<tr><td align="right"> 出 版 日 期 </td> 
«td .class-"tdd"»«?php. echo substr($book[0]['pub date'],0, 
10); ?5»«/td»4/tr» 
«tr»«td align="right"> 书 号 </td> 








<?php echo $book[0] ['book 





«td class="tdd"><?php echo $book[0]['book no']; ?></td></tr> 
<tr><td align="right"> 原 价 </td> 
«td class="tdd"><?php printf ("%.2f", $book[0] ['price']); ?></td></tr> 


<tr><td alig, zight"> 折 扣 价 </td> 

<td class-"tdd"»«?php echo $book[0]['book 1 price']; ?»«/td»«/tr» 
<tr><td align="right"> 会 员 价 </td> 

«td class="tdd"><?php echo $book[0]['price m']; ?»«/td»«/tr» 
<tr><td align-"right"»^$44«/td» 








<td class-"tdd"»«font color: FF000 

level'];?» «/font»&nbsp;ZK&nbsp; &nbsp; <img src= 
level pic'];?»" /></td></tr> 

<tr><td colspan-"3"»jijfi&nbsp; &nbsp;«span class-"tdd"»«?php echo 
$book[0] ['book abstract'] ;?»«/span»«/td»«/tr» 

<tr><td colspan-"3"»[HoK«pre class-"tdd"»«?php echo $book[0] ['book 
index'];?» «/pre»«/td»«/tr» 

«tr»«td colspan-"3" align-"center"»«a href="#" onClick- "javascript: 
window.close();return false; "> 返回 </a></td></tr> 





><?php echo $book[0]['book . 
<?php echo $book[0]['book | 








1 m 
N 
- 
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</table> 
<table width="100%" border="1" cellspacing="1" class="tdl"> 
<tr><td id="bt"> 访 客 评价 信息 <hr/></td></tr></table> 
«table width-"100$" border-"1" cellspacing-"1" class-"tdl"» 
<tr><td colspan="4">&nbsp; 目 前 对 本 书 的 评价 有 <?PhP echo $num ;?»4&. 
«/td»«/tr» 
«tr align-"center"id-"bb"» 
«td width="20%"> 用 户 名 </td><tqd width="20%"> 评 价 等 级 </td><td> 评 价 内 
容 </td><td> 评 价 时 间 </td></tr> 
<?php 
if ($num»0)( 
for ($j=0;$j<count ($usermsg) ; $j++) ( 


echo"«tr class-'tdl'»«td»".S$usermsg[$j]['user- id']."«/td»"; 

echo"«td»".$usermsg[$j]['book level']."«/td»"; 

echo'«td»'.$usermsg[$j] ['message content!'].'«/td»'; 
echo'«td»'.S$usermsg[$j]['message time!].'«/td»«/tr»'; 





<tr><td colspan align 
«tr align-"center" id 





"center"»&nbsp;«?php echo $msg; ?»«/td» </tr> 
bb"»«td colspan="4"> 我 要 评书 </td></tr> 








<formaction="user fback.php?bookid-«?php echo $bookid; ?>" method= "post"> 
<tr><td width="20%" ‘align="right"> 用 户 名 </td> 

«td colspan="3"><input name-"user id" type="text" size="68" 

id-"textfield" /»*«/td»«/tr» 

<tr><td align-"right"»i] 





价 等 级 </ td> 

«td class-"tdd" colspan-"3"»«input type="radio" name-"book level" 
value-"5"ide"RadioGroupl 0"/»[Blf&nbsp; &nbsp; 

Xinput type="radio" name-"book level" value-"4" id="RadioGroupl_0"/> 较 好 
&nbsp; &nbsp; 

«input name-"book level" type-"radio" id-"RadioGroupl 1" value-"3" /» 
lif&nbsp; &nbsp; 

<input type="radio" name-"book level" value 
一 般 &nbsp; &nbsp; 





" id-"RadioGroupl 2"/> 


<input type="radio" name-"book level" value-"1" id-"RadioGroupl 2"/» 
差 snbspy &nbsp; 
<input type="radio" name-"book level" value-"0" id-"RadioGroupl 2"/» 
很 差 </td></tr> 
<tr><td align="right"> 评 语 内 容 </td> 





«td class-"tdd" colspan="3"><textarea name-"comm" cols-"60" rows- 
id-"textfield3"» «/textarea»«/td»«/tr» 
<tr><td colspan-"4" align-"center"»«input type="submit" 
name-"button" id="button"value=" 提 交 "/></td></tr> 
«/form» 
</table> 
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</div> 
</body> 
</html> 


(3) 把 文档 以 book_fullinfo.php 为 文件 名 保存 在 webshop 文件 夹 下 。 


Bi ass 


book fullinfo.php 实现 对 图 书信 息 的 详细 显示 。 
第 1 一 13 fr: 根据 URL 传递 的 图 书 序列 号 提取 数据 表 bookinfo 中 的 图 书 数据 ， 同 时 也 提取 数据 表 
usermessage 中 对 图 书 的 反馈 信息 。 

第 26 行 : 向 浏览 器 输出 具有 bb 样式 的 空 

第 28 一 51 行 : 以 表格 的 方式 组 织 详细 图 书信 息 显 示 。 其 中 
第 31 行 : 跨 9 行 显示 图 书 的 封面 图 像 . 

第 54 一 84 行 : 以 表格 的 方式 显示 用 户 对 该 图 书 的 反馈 信息 ， 
第 70 一 83 fr: 提供 用 户 对 该 图 书 的 反馈 信息 


3. 用 户 评 书 反馈 信息 处 理 
代码 文件 : user_fback.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， VE e" 视图 ， 输 入 如 下 代码 。 


<?php Td Kz 
require_once (' include/control. inc. php. 57 Fili t e AR REIS Sc 
$bookid-1; Suserid-""; $booklevel--1;S$bookcomm-""; 
if (isset($, GET( 'bookid'])) $bookid=$. GET['bookid']; // 获 取 图 书 序列 号 bookid 
if (isset 人 SPosT[' user id'])) Suserid-s | PosST['user id']; // 获 取 图 书 序列 号 bookid 
Eum (isset($ 1 POST['book level']))' $booklevel-(int)$ POST['book level']; 
DIRNE bookid 
if(isset($ POST['comm'])) $bookcomm=$_POST['comm']; // 获 取 表 单数 据 
if ($userid!="" && $booklevel»-0)( 
$usermsg-new control(); // 创 建 反馈 用 户 对 象 
$sql="INSERT INTO ueser message (user id,book id,book level,message content. 
VALUES (' $userid', '$bookid','$booklevel', '$bookcomm')"; // 插 入 数据 的 SOL 语句 
$usermsg-»insert ($sql); 
$book s-new control(); // 创 建 图 书 对 象 
$sql-"SELECT * FROM book info WHERE book id-".$bookid; 
$book-$book s-»select($sql); // 使 用 基本 操作 类 中 的 方法 select ($sql) 查询 数据 集 
$level=floor ( ($booklevel+$book[0] ['book level'])/2); 
$sql="UPDATE book info SET book level = ".$1evel." WHERE book id=".$bookid; 
$book-$book s-»update($sql); // 使 用 基本 操作 类 中 的 方法 select ($sq1) 查询 数据 集 
$sql-"UPDATE book info SET book level pic='images/level/".$level. 
"star.gif' WHERE book id-".$bookid; 
$book=$book_s->update ($sql); // 使 用 基本 操作 类 中 的 方法 select ($sq1) 查询 数据 集 
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echo "«meta http-equiv-'Refresh' content-'0;url-book fullinfo.php?bookid-". 
Sbookid."'»"; 
?> 





(3) 把 文档 以 user_fback.php 为 文件 名 保存 在 webshop 文件 夹 下 。 
4. main.php 中 的 图 书 人 
代码 文件 ，main.php 





(1) 在 Dreamweaver 中 ， 打 开 文件 main.php。 
(2) 切换 到 “代码 ”视图 ， 添 加 如 下 代码 


<table width="580" border-"0" cellspacing-"0" > 
«?php 
require once('webshop/include/control.inc.php!); 
$books-new control(); 
$bookDBname-"book hot"; 
$serach-" 1 ORDER BY hot order ASC LIMIT 0,2"; // 从 数据 表 中 前 2 条 记录 
$book=$books->Getbookdata ($bookDBname, $serach); // 获 取 显 示 图 书 的 信息 
$count=count ($book) ; 
$i-0; 
while(Si«$count)( // 输 出 要 显示 图 书 的 信息 到 相应 的 单元 格 中 
$book name d-$books-»Getstr($book[$i]['book. name'],18); 
?> 
<td width="55"><a href-'webshop/book fullinfo.php?bookid-«?php echo$book[$i] 
['book id']; ?»' target-' blank'»«img id-"imgc" src="webshop/<?php echo 
$book [$i] ['book.pic'];?»"/»«/a»«/td» 
«td width2"240"»4:«?php echo $book name d;?»«br/» 
ISBN:«?php echo $book[$i]['book no'];?»«br/» 
出 版 社 :<?php echo $book[$i] ['publisher']73?> 出 版 社 <br/> 
原价 :RMB&nbsp;<?php echo $book[$i]['price'];?>&nbsp; 元 <br/> 
会 员 价 : RMB&nbsp; <?php echo $book[$i] ['price_m'];?>&nbsp; 元 </td> 
<?php $i++; }?> 
</tr> 
</table> 


<table width="580" border="0" cellspacing="0"><tr> 
<?php 

$bookDBname="book_sale"; 
$serach-" 1 ORDER BY sale order ASC LIMIT 0,2"; // 从 数据 表 中 前 2 条 记录 
$book-$books-»Getbookdata($bookDBname,$serach);  // 获 取 显 示 图 书 的 信息 
$count=count ($book); $i-0; 
while ($i<$count){ // 输 出 要 显示 图 书 的 信息 到 相应 的 单元 格 中 

$book name d=$books->Getstr($book[$i]['book name'],18); 




















?> 
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<tdwidth="55"><a href-'webshop/book fullinfo.php?bookid: 
['book id'];?» 'target-' blank'»«img id-"imgc" alt=" 暂 缺 " sr 
$book[$i]['book pic'];?>"/></a></td> 
<td width="240"> 书 名 :<?php echo $book name d;?><br/> 
ISBN:«?php echo $book[$i]['book no'];?><br/> 
出 版 社 :<?php echo $book[$i]['publisher'];?> 出 版 社 <br/> 
原价 :RMB&nbsp;<?php echo $book[0] ['price'];?>&nbsp; 元 <br/> 
优惠 :<?php echo $book[$i]['book 1 price'];?>&nbsp; 折 </td> 





?php echo $book [$i] 
webshop/«?php echo 









«?php $i++; } ?> 
</tr></table> 


<table width="580" border="0" cellspacing="0"><tr> 





<?php 
$bookDBname-"book recommend"; kK 
$serach-" 1 ORDER BY recom order ASC LIMIT 0,2"; // 从 数据 表 中 前 2 条 记录 
$book=$books->Getbookdata ($bookDBname, $serach); // 获 取 显示 图 书 的 信息 


$count=count ($book); $i=0; | 
while(Si«$count)( // 输 出 要 显示 图 书 的 信息 到 相应 的 单元 格 中 
$book name d=$books->Getstr ($bookI$i] ['book name'],18); 





?> 
«td width="55"><a href-"webshop/book fullinfo.php?bookid-«?php echo 
$book[$i]['book id'];?»"targetz" blank"»«img id-"imgc" src-"webshop/«?php 
echo $book[S$i]['book, pic']; ?>" /»«/a»«/td» 
«td width="240"> 书 名 :<?php echo $book name d;?»«br/» 
ISBN:«?php echo $book[$i]['book no'];?»«br/» 
出 版 社 :<?php echo $book [$1] ['publisher'];?> 出 版 社 <br/> 
会 员 价 :RMB&gnbsp;<?Phip echo $book[$i]['price m'];?>&nbsp; 元 <br/> 
评级 :<font colors"$FF0000"2«?php echo $book[$i]['book level']; ?> 
</font>&nbsB; 级 snbsp; &nbsp; «img src-'webshop/«?php echo $book[$i] ['book level. 
pic']; ?>' height-"10" /></td> 
<?php $i++;}?> 
</tr></table> 





(3) 保存 文件 。 


7.8.4. 购物 车 


1 


1， 加 入 购物 车 
代码 文件 ，cart_add.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


«?php 
Gsession start () ;// 启 动 会 话 


PHP 动态 网 页 设计 与 制作 案例 教程 (第 己 版 ) 


$msgl-""; $userid-""; 

if(isset($ SESSION['userid'])) $userid-$ SESSION['userid']; // 获 取 会 话 数据 
require once('include/control.inc.php'); // 请 求 包含 相应 类 的 文件 
$bookbmm-array(); $booknumm=array (); 

$title=""; $search=""; $DTname-"";$page-1; // 初 始 化 变量 

if(isset($ POST['bookbm'])) Sbookbmm-$ POST['bookbm']; 

if(isset($ POST['buynum'])) $booknumm-$ POST['buynum']; // 获 取 提 交 表 单 的 数 
if(isset($ GET['title'])) $title=$ GET['title']; 

if(isset($ GET['DTname'])) SDTname-$ GET['DTname']; 

if(isset($ GET['page'])) S$page-$ GET['page']; 

if(isset($ GET['search'])) Ssearch-$ GET['search']; 

if(isset(S POST['page'])) Spage-S GET['page']; // 获 取 URL 传递 的 数据 
$url="book show.php?title-$title&&DTname-S$DTname&&search-$search&&page-"; 
$userIP-$ SERVER['REMOTE ADDR'];  //3KkHUHJ"(rjred&hk, MRA 





$cart-new control(); // 创 建 购物 车 对 象 
foreach ($bookbmm as $key=>$value){ // 寻 找 并 处 理 被 选中 的 图 书 
$search-"(cart session id -'".$userIP."' AND book id=".$key.")"; 


if ($value--"sel")( 
if ( (int) $booknumm[$key]<1){ 
$msg1 .=" 所 选 图 书 ".$key HKEE E EM 





数 !<brV>"7 
) 
else{ 
$DTname-"book “cart"; 
$cart s4$cart-»GetDTdataset($DTname,$search);  // 查 询 用 户 是 否 这 
购 过 这 本 书 
if(count($cart s)--0)4 // 没 有 选 购 的 处 理 
$sql-"INSERT INTO book cart(user id, book id, buy num, 
cart session id) VALUES ('S$userid','$key', '$booknumm[S$key] ', '$userIP')"; 
Spp-$cart-»insert($sql);  // 插 入 到 购物 车 表 中 
} 
else( // 选 购 过 的 处 理 
$booknu-$cart s[0]['buy num']+$booknumm[$key]; 
$sql -"UPDATE book cart SET buy num-".$booknu." WHERE" .$search; 
$pp-$cart-»update($sq1l);  // 以 累加 值 更 新 购书 数量 
} 
if ($pp) { 
Smsg1 .=" 所 选 图 书 ". Skey . "添加 成 功 !<br/>"; // 成 功 操作 后 的 反馈 信息 








// 没 有 选中 图 书 的 反馈 信息 
?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
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"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" 
<title> 图 书 显示 </title> 


<link href="css/bscss.css" 
</head> 


<body> 
<div id="appb"> 
«div id="bt"> 购 书 反 馈 信息 <hr /></div> 
«table width="600" border="0" cellspacing="0" class-"tdl"» 


rel="stylesheet" type="text/css" /> 


«tr id-"bb" align-"center"»«td colspan="3"><?php echo $msgl; ?></td></tr> 
<tr><td align-"right"»«form metho post" action="<?php echo 
?>"><input type="submit" value=" 继 续 选 书 &gt 广 gt;"></form></td> 

«td width="12">&nbsp;</td><td aligne"lef£m 
«form method-"post" action-"cart _ check. php?page- 1"»«input type= 


"submit" value=" 查 看 购物 车 &1lt; Lui. cs 
</table> 


</div> 
</body> 
</html> 





$url; 





(3) 把 文档 以 cart_add.php 为 文件 名 保存 在 webshop 文件 夹 下 
e. 8248 2 


cart add.php 实现 用 户 在 图 书 列表 中 选择 所 要 购买 的 图 书 并 填写 购买 数量 后 放 入 购物 车 后 的 处 理 。 
第 2 一 4 行 : 用 户 选 购 图 书 就 开始 了 与 系统 的 会 话 . 需要 获取 用 户 的 ID 信息 ， 如 果 用 户 还 没有 注册 ， 
则 用 户 的 ID 为 ""。 
第 16 行 : 获取 用 户 的 IP 地 址 作为 对 本 机 购书 用 户 的 一 个 标识 
第 17 一 44 行 : 对 用 户 购 书 表单 的 处 理 。 其 中 : 
第 18 一 41 行 : 当 用 户 选 中 了 想 购买 的 图 书 ， 依 次 寻找 并 处 理 选中 的 图 书 。 
第 19 行 : 设置 查询 购物 车 上 该 用 户 对 该 书 的 购书 条 件 。 
第 20 一 41 行 : 处 理 图 书 被 选中 。 
第 22 行 : 若 没 有 填写 购买 数量 ， 则 设置 反馈 信息 。 
第 24 一 40 f: 填写 了 合法 的 购书 人 
第 27 一 30 行 : 该 用 户 没 有 选 购 过 该 书 ， 直 接 插入 到 购物 车 表 中 。 
第 31 一 35 行 : 该 用 户 选 购 过 ， 要 与 原来 的 购买 量 累 加 并 更 新 表 bookcart 的 字段 buy_num。 
第 36 一 38 行 : 设置 所 选 图 书 添加 成 功 的 1 
第 43~44 行 : 设置 用 户 没有 选中 任何 图 书 的 反馈 
第 59 一 61 行 : 向 该 用 户 提 供 操作 反馈 人 
2. 查看 购物 车 


代码 文件 : cart check.php 























， 同 时 设置 了 两 个 表单 ， 设 置 按钮 实现 对 页 面 的 重 定向 。 


PHP 动态 网 页 设计 与 制作 案例 教程 (第 己 版 ) 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 
ji“ 代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
















«?php 
Gsession start(); // 启 动 会 话 
$msgl-""; $userid-""; 
if(isset($ SESSION['userid'])) $userid=$ SESSION['userid']; 
require once('include/control.inc.php'); 
require once('include/display.inc.php');  // 请 求 包含 相应 类 的 文件 
$search=""; $page=0; 
if(isset($ GET['title'])) $title=$ GET['title']; 
if(isset($ GET['page'])) S$page=$ GET['page']; // 获 取 URL 传递 的 数据 
if(isset($ POST['page'])) $page-$ POST['page'];  // 获 取 POST 传递 的 数据 
$userIP-$ SERVER['REMOTE ADDR']; ”// 获 取 用 户 的 TP 地 址 ， 以 识别 用 户 
if($page«1) $page-1; 
$carts-new control(); // 创 建 购物 车 对 象 
$DTname-"book cart";$search-"cart session ID .SuserIP." 
$cart s-$carts-»GetDTdataset ($DTname, $search) ; // 获 取 购 物 车 信和 


$book s-$carts-»Getbookdata($DTname,$search); ”// 获 取 购 物 车 上 所 有 的 图 书信 息 

$carts-»closedb(); 

Surl-"cart check.php?page-"; 

$displaycart-new display(); // 创 建 购物 车 显示 的 对 象 

$displaycart-» pageSize=$carts-> pageSize; 

Spagelast-$displaycart-»GetpageNum($cart s); 

$cart-$carts-»GetcontrolList($cart s,$page); 

Sdisplaybar-$displaycart-»GetJumpBar (Scart. s, $page,$url); // 生 成 购物 车 显示 
的 页 面 导 航 栏 





?» 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 

"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 

<html xmlns-"http://www.w3.0rg/1999/xhtml"» 

<head> 

<meta http-equi Content-Type" content="text/html; charset=utf-8"> 
<title> 查 询 购 物 车 </title> 
<base target="mainFrame"> 





<link href="css/bscss.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="appb"> 
«div id="bt"> 查 看 购物 车 <hr /></div> 
«form action-"«?php echo $url.$page; ?>" method="post" target="mainFrame"> 
«table width-"600" border-"0" cellspacing-"0" class-"tdl"» 
<tr><td height-"24" > 共有 <?php echo count($cart s); ?> 本 书 &nbsp; 
&nbsp; 共 <?php echo $pagelast; ?> 页 &nbsp;&nbsp;<?php echo $displaybar 
['JumpBar']; ?></td> 
«td align-"right"» 输入 页 次 : <input type-"text" size-"3" name-"page" 
><input type-"submit" name-"send2" value=" 转 到 " /></td></tr> 
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</table> 
</form> 
<table width="600" borde 
<form method="post" actio 





cellspacing= class-"tdl"» 





cart update.php?page-«?php echo 
$page; ?>" target-"mainFrame"» 
«tr align="center" id="bb"><td> 取 消 </td><td> 书 名 </td><td> 作 者 </td> 
<td> 出 版 社 </td><td> 单 价 </td><td> 购 买 数量 </td><td> 合 计 </td></tr> 
«?php 
for ($j=0; $j<count ($cart) ; $j**) ( // 输 入 选 购 图 书 的 信息 
echo '«tr»«td»«input type="checkbox" name-"bookbm['.$cart[$j] ['book 
id'].']" value-"del"» '.$cart[$j]['book id'].'«/td»'; 
echo "«td»".$carts-»Getstr($book s[$j]['book name'],18) ."«/td»"; 
echo "«td»".$carts-»Getstr($book s[$j]['author'],10)."«/td»"; 
echo "«td»".$book s[$j]['publisher']."«/td»"; 
echo "«td»".$book s[$j]l['price']*S$book s[$jl['book 1 price']."«/td»"; 
echo '«td»«input type="text" size-"6" name-"buynum['.$cart[$j]['book - 


id'].']" value-"'.$cart[$j] ['buy num'].'"»«/td»'; 

echo "«td»".$book s[$jl['price']*$book s[$j] ['book l price']*$cart[$j] 
['buy num']." </td></tr>"; 

) 
?> 


<tr><td colspan-"7" align-"right"»«?php echo $displaybar['msg']; ?></td> 
</tr> 
<tr id="bb"><tdcolspan="5"> 单 击 取消 复 选 框 或 修改 购书 数量 ， 再 单 击 “ 修 改 ” 按 钮 ， 
就 能 修改 所 买 <bz/> 如 果 确 定 了 要 买 的 书 ， 可 以 单 击 “ 下 订单 ”按钮 </td> 
«td align-"center"»«input type-"submit" value=" 修 改 "” /»«/td» 
«td»«input type="button"valie=" 下 订单 " onclick-"window.location. 





replace('ordér check.php')"/»«/form»«/td»«/tr» 
S/form» 
«/table» 
<div align="center" class-"tdl"»&nbsp;«br/»&nbsp;«/div» 
</div> 
</body> 
</html> 





(3) 把 文档 以 cart_check.php 为 文件 名 保存 在 webshop 文件 夹 下 。 
e. 
MORBA 


cart_check.php 生成 购物 车 查询 列表 清单 。 采 用 分 页 显示 技术 ， 同 时 提供 用 户 修改 选 购 信息 的 方式 。 
第 45 一 56 行 : 根据 序列 号 依次 在 对 应 的 单元 格 中 显示 购物 车 中 的 图 书信 息 ， 同 时 在 第 1 列 设置 了 复 选 框 ， 
第 6 列 设置 了 文本 输入 框 ， 以 供用 户 修改 选 购 信息 


3. 修改 购物 车 
代码 文件 : cart_update.php 





PHP 动态 网 页 设计 与 制作 案例 教程 (第 己 版 ) 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 








Q) 单 击 “ 代 人 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 
<?php 
@session_start(); // 启 动 会 话 
$msgl-""; $userid=""; 


if(isset($ SESSION['userid'])) $userid=$ SESSION['userid']; 
require once('include/control.inc.php'); // 请 求 包含 相应 类 的 文件 
$bookbmm=array(); $booknumm-array(); 
$search-""; $pp="";$page=""; // 初 始 化 变量 的 值 
if(isset($ POST['bookbm'])) $bookbmm-$ POST['bookbm']; 
if(isset($ POST['buynum'])) $booknumm-$ POST['buynum']; // 获 取 提 交 表单 的 数 
if(isset($ GET['page'])) $page=$_GET['page']; // 获 取 URL 传递 的 数据 
$userIP-$ SERVER['REMOTE ADDR']; // 获 取 用 户 的 IP 地 址 ， 以 识别 用 户 
$cart-new control(); // 创 建 购物 车 对 象 
if (count ($booknumm) >0) { ”// 处 理 用 户 更 改 了 购买 数量 
foreach ($booknumm as $key=>$value), 1 
if ( (int) $value<=0) 
$msg1 .=" 所 选 图 书 " - Skey . "的 购买 数量 应 该 为 正 整数 !<br/>"， 
else( 





$DTname-"book cart"; 
$search=" (cart session id-'".$userIP."' andbook id-".$key 
$cartss-$cart-»GetDTdataset(S$DTname,$search);  // 获 取 购 物 车 


"yn; 








if((int)S$valuec»S$cartss[0] ['buy num" ]) ( 
$sql ="UPDATE book cart SET buy. num-" .$value." WHERE ".$search; 
$pp-$cart-»update ($sql) ; 
if($pp)t 
$msg1. =" MAP" $key. "BURI ! <br/>"; 





if (count ($bookbmm) >0) { // 处 理 用 户 更 改 了 购买 数量 
foreach ($bookbmm as $key-»$value)( // 处 理 用 户 选中 取消 复 选 框 
if ($value--"del")| 

$sql-"DELETE FROM book cart WHERE (cart session id 
-'",S$userIP."' AND book id-".$key.") "; 

$pp-$cart-»delete ($sql); 

$sql-"ALTER TABLE book cart DROP cart id "; 

$pp-$cart-»delete ($sql); 

$sql-"ALTER TABLE bookcart ADD cart id INT(11) NOT NULL AUTO 
INCREMENT PRIMARY KEY FIRST"; 

$pp-$cart-»delete ($sql); 

$msg1.=" 所 选 图 书 " . $key." 








么 取消 购买 !<br/>"; 
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) 

$cart-»closedb(); 

t 

$msg1=" 没 有 选择 修改 的 方式 ! <br/>"; 





?» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 


<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 





<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title> 修 改 购书 信息 </title> 
<link href="css/bscss.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="appb"> 
«div id="bt"> 修 改 购书 信息 <hr /></div>、 
«table width="600" border-"0" cellspacing-"0" class-"tdl"» 
<tr id-"bb" align-"center"»«td colspan-"3"»«?php echo $msg1; ?»«/td»«/tr» 
<tr><td align-"left"»«form method="post" action-"cart check.php?«?php 
echo $page; ?> "><input type-"submit" value-"jAR[n&lt; &lt; »«/form»«/td»«/tr» 
</table> 
</div> 
</body> 
</html> 





(3) 把 文档 以 cart_update.php 为 文件 名 保存 在 webshop 文件 夹 下 。 





B easi 
cart, update.php 用 于 处 理 在 cart check.php 中 的 用 户 操作 . 主要 有 两 个 : 取消 购书 (选中 复 选 框 ): 和 更 改 
购买 数量 (重新 填写 文本 框 )。 
第 6 行 : 设置 用 于 获取 由 cart_check.php 中 表单 提交 的 数据 的 变量 ， 由 于 用 户 可 以 复 选 或 更 改 多 个 文 
本 框 ， 因 此 获得 的 数据 是 以 数组 方式 提交 的 . 
第 12 一 30 行 : 处 理 用 户 更 改 购书 数量 。 若 修改 数据 不 合法 ， 则 设置 反馈 信息 ; 若 修改 数据 合法 ， 则 
更 新 相关 字段 并 设置 反馈 信息 。 
第 31 一 43 行 : 处 理 用 户 选 中 复 选 框 。 删除 选中 的 记录 并 重新 排序 购物 车 中 记录 的 序号 ， 设 置 反 馈 信 息 。 
第 46 行 : 如 果 没 有 设置 反馈 信息 ， 则 说 明 没 有 修改 任何 信息 ， 设 置 反 馈 信 息 。 
4. 清空 购物 车 
代码 文件 : cart_clear.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


PHP 动态 网 页 设计 与 制作 案例 教程 (第 己 版 ) 


«?php 
session start(); // 启 动 会 话 
$msgl-""; $userid= $button= 
if(isset($ SESSION['userid'])) $userid=$ SESSION['userid']; 
$userIP-$ SERVER['REMOTE ADDR']; // 获 取 用 户 的 IP 地 址 ， 以 识别 用 户 
if(isset($ POST['sub'])) Sbutton-$ POST['sub']; 
require once('include/control.inc.php'); // 请 求 包含 相应 类 的 文件 


$carts=new control(); 


$count=0; 





$DTname="book cart";$search="cart session id -'".$userIP."'"; 
$cart s-$carts-»GetDTdataset($DTname,$search); // 获 取 购 物 车 
if(count($cart s)--0)( // 确 认购 物 车 上 是 否 有 图 书 
$msg=" 购 物 车 为 空 !<br/> 购 物 车 中 没有 选 购 的 图 书 
Il"; 
Surl-"../main.php"; 
) 
else( // 确 认购 物 车 上 的 图 书 是 否 已 经 生成 订单 
for($i=0;$i<count ($cart s);$i**)( 
if ($cart_s[$i] ['order_id']==0) .Secount++; //0 表示 未 生成 订单 
) 
if($count--0) ( // 购 物 车 上 的 图 书 已 经 生成 订单 
$msg=" 购 物 千 需 gz!<br/> 购 物 车 中 选 购 的 " .count ($cart_s) . "图 书 已 经 生成 订单 1"; 
$submit-"[j 














$submit-"jk 





WE"; 
$url-"cart clear.php"; 

) 

else( // 购 物 车 下 的 图 书 未 生成 订单 

$msg=" 购 物 车 i?«br /> 购物 车 中 选 购 的 ". $count ." 本 图 书 尚未 生成 订单 1"; 
$submit=" 确 定 "; 





$url-"Ccart clear.php"; 


if (Sbutton==" 确 定 ") { // RI FR A ES EHI E 

$sql-" DELETE FROM book cart WHERE cart session id -'$userIP'"; 

$carts-»delete ($sql); 

$sql- "ALTER TABLE book cart DROP cart id;"; 

$carts-»delete ($sql); 

$sql= "ALTER TABLE book cart ADD cart id INT(11) NOT NULL AUTO INCREMENT 
PRIMARY KEY FIRST;"; 

$carts->delete ($sql); 

$msg=" 购 物 车 已 清空 !<br/> 购 物 车 中 没有 选 购 的 图 书信 息 !"; 

$submit=" 返 回 "; 

$url="../main.php"; 





$carts-»closedb(); 

) 
Er 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
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«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title> 清 空 购物 车 反馈 信息 </title> 
<link href="css/bscss.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="appb"> 
«div id="bt"> 清 空 购物 车 反馈 信息 <hr /></div> 
«table width-"600" border="0" cellspacing="0" class-"tdl"» 
«tr id-"bb" align-"center"»«td colspan-"2"»«?php echo $msg; ?»«/td»«/tr» 





«tr align-"center"»«td»«form method-"post" action-"«?php echo 
$url; ?»"»«input type="submit" name-"sub" value-"«?php echo $submit; ?>"> 
«/form»«/td» s 
<?php if ($count<>0){ ?> 

<td align="right"><form method="post" Qi tene cart. check.php? «?php 
echo $page; ?»"»«input type="submit" value=" fofi sot; agt; "»«/form»«/td» 
«?php ) ?» CA 

«/tr» : NI 
</table> 
</div> 
</body> OY 

</html> > 


(3) 把 文档 以 cart_clearphp 为 文件 名 保存 在 webshop 文件 夹 下 。 





quos 


cart_clearphp\ 实 现 了 对 购物 车 的 清空 功能 . 根据 不 同情 况 提 供用 户 反馈 ,设置 用 户 下 一 步 的 操作 ， 
第 11 一 15 行 : 对 购物 车 上 没有 选 购 图 书 的 反馈 ， 设置 用 户 的 操作 为 “返回 ”主页 。 
第 16 一 30 行 : 当 购 物 车 上 有 选 购 的 图 书 时 ， 要 区 分 是 否 生成 了 订单 。 其中: 

第 17 一 19 行 : 统计 购物 车 上 未 生成 订单 的 图 书 。 

第 20 一 24 行 : 对 购物 车 上 生成 订单 的 反馈 ， 设 置 用 户 的 操作 为 “确定 ”和 “查看 购物 车 ”。 

第 25 一 29 行 : 对 购物 车 上 未 生成 订单 的 反馈 ， 设 置 用 户 的 操作 为 “确定 ”和 “查看 购物 车 ”。 
第 31 一 42 行 : 用 户 确认 要 清除 购物 车 的 处 理 ， 删 除 记录 并 对 序列 号 重新 排序 .设置 反馈 和 “返回 ” 

操作 。 

第 57 行 : 用 户 的 操作 通过 按钮 表单 实现 ， 按 钮 的 名 称 可 能 是 “ 确 疾 “返回 ”， 由 表单 中 的 设置 而 定 。 
第 58 一 60 行 : 当 购物 车 上 存在 尚未 生成 订单 的 图 书 时 ， 用 户 可 以 通过 按钮 实现 “查看 购物 车 ”操作 。 


7.8.5 “订单 处 理 
l 下 订单 
代码 文件 : order_check.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
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(2) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 
<?php 
Qsession_start (); // 启 动 会 话 








$msgl- Suserid-""; 

if(isset($ SESSION['userid'])) $userid=$ SESSION['userid']; 

$ SESSION['userid']-$userid; 

$userIP-$ SERVER['REMOTE ADDR']; // 获 取 用 户 的 IP 地 址 ， 以 识别 用 户 

require once('include/control.inc.php'); // 请 求 包含 相应 类 的 文件 

$bcob=new control(); 

$DTname="book cart";$search="cart session id-'".$userIP ; 

$cart s-$bcob-»GetDTdataset($DTname,$search); // 获 取 购 书 车 信息 

$bcob-»closedb(); 

if(count($cart s)--0)( // 确 认购 物 车 
$msg=" 购 物 车 上 没有 图 书 ， 不 能 下 订单 !"; 

HEH"; 


$url="../main.php"; 








无 图 书 的 反馈 和 操作 设置 








) 
else( // 确 认购 物 车 上 有 图 书 
if ($useri { // 设 置 用 户 没有 登录 的 反馈 和 操作 
$msg=" 还 没有 登录 !<br/> 请 您 先 登录 ; 上 表 下 订单 1"; 
$submit=" 去 登录 "; 
$url="'../register/regiridex.php' target-' blank'"; 








) 

else( // 设 置 用 户 
$msg=" 确 认 要 下 订 
$submit=" 确 定 " 
$url="'bòok order.php' target-" blank'"; 


的 反馈 和 操作 
? <br/> 确 定 要 购买 购物 车 上 上 的 图 书 !1"; 













?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 





<title> 下 订单 反馈 信息 </title> 
<link href="css/bscss.css" rel="stylesheet" type="text/css" /> 

</head> 

<body> 


<div id="appb"> 
<div id="bt"> 下 订单 反馈 信息 <hr /></div> 
«table width-"600" border="0" cellspacing="0" class-"tdl"» 
«tr id-"bb" align-"center"»«td colspan-"2"»«?php echo $msg; ?»«/td»«/tr» 
«tr align="center"> «td»«form method="post" action-«?php echo $url; ?> > 
<?php if(count($cart s)>0){ ?> 
«a href-"cart check.php"» «input type-"button" name-"sub" value-" 
返回 ”></a> 
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«?php }?> 
&nbsp; <input type="submit" name-"sub" value-"«?php echo $submit; ?>" 
onmousedown- "window.close();"» 
«/form»«/td»«/tr» 
</table> 
</div> 
</body> 
</html> 





(3) 把 文档 以 order_check.php 为 文件 名 保存 在 webshop 文件 夹 下 。 


eani 
order. check.php 实现 对 用 户 下 订单 前 的 一 系列 检查 ， 包 括 是 否 选 购 了 图 书 几 是 否 登录 ， 并 根据 检查 结 
果 设 置 反 馈 信息 和 操作 。 与 cart_clear.php 类 似 
2， 确 认 订单 
代码 文件 : book_orderphp、order_p.php、exitphp 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 





«?php 
Gsession start(); JAIA 
$msg-""; Suserid-""; 
if(isset($ SESSION['userid'])) :$userid-$ SESSION['userid']; 
$userIP-$.SERVER['REMOTE ADDR']; AZ7Y 获 取 用 户 的 IP 地 址 ， 以 识别 用 户 
$button=$ POST['sub']; 
reduire once('include/control.inc.php'); // 请 求 包含 相应 类 的 文件 
if(isset($ GET['msg'])) $msg-$ GET['msg']; 
$bcob-new control(); 
$DTname-"book cart";$search-"cart session id -'".$userIP."'"; 
$cart s-$bcob-»GetDTdataset(S$DTname,$search); // 获 取 购物 车 信息 
$book s-$bcob-»Getbookdata($DTname,$search);  // 获 取 购物 车 上 所 有 的 图 书信 息 








?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«head» 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8"» 
<title> 订 单 信息 确认 </title> 
<base target="mainFrame"> 
<link href="css/bscss.css" rel="stylesheet" type="text/css"/> 
</head> 
<body> 
<div id="appb"> 
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«div id="bt"> 确 认 订单 信息 <hr/></div> 
<div id="bb"><?php echo $userid; ?>: 您 的 购书 清单 ! 
<p class="tdl"> 共 有 <?php echo count($cart s); ?> 本 书 </p></div> 
«table width="600" border-"1" cellspacin 
<tr id="bb" align="center"><td width="30% 
作者 </td> 
<td> 包 装 说 明 </td><td> 出 版 社 </td><td> 价 格 </td><td> 购 买 数量 </td><td> 
合计 </td></tr> 


"I" class="tdl"> 
> 书 名 </td><tqd width="25%"> 






<?php 
$b id-"";$b num-"";$total-0; 
for($j-0;$j«count($cart _s);$j++){ // 输 出 选 购 的 图 书信 息 
if ($book_s[$j]['book bs']==0) $bz=" 平 装 "; else $bz=" 精 装 "; 








echo "«tr»«td»".$book s[$j]['book name']."«/td»«td»". S$book s[$j] 
D'author*] "etd" 

echo "<td aligns'center'»".$bz."«/td»"; 

echo "<td align-'center'»".$book s[$j]["'publisher']."«/td»"; 

echo "<td aligns'center'»".$book s[$j]['price m']."«/td»"; 





echo "<td align-'center'»".$cart s[$j]['buy num']."«/td»"; 
echo "<td align-'center'»".$book-s[$j] ['price m']*$cart s[$j]['buy 
num']." «/td»«/tr»"; 
if ($j==0){ 
$b id-$cart s[$j]['book id']; 
$b num-$cart s[$j]["*buy num']; 
) 
else( 
$b id.-","7$cart s[$j]['book id]; 
$b num.- 








".Scart s[$j]['buy num']; 
) 
$total*-$book s[$j]['price m']*$cart s[S$j]['buy num']; // 计 算 购 书 的 金额 
) 
echo "<tr id-'bb'»«td colspan-'5' align-'right'^» [kis Wic/td»"; 
echo "<td colspan-'2'»".$total." &nbsp; &nbsp;7ü«/td»«/tr»"; 
Sb lds ".$b num; ”// 记 录 购 买 的 每 本 书 的 书号 和 数量 
$ SESSION['b id']-$b id;$ SESSION['b money']-$total; 
$ SESSION['bk num']-count($cart s); // 把 购买 的 书号 、 数 量 和 金额 保存 在 SESSION 








require once('include/user.inc.php'); 

$user-new user(); 

$sql u-"SELECT * FROM userinfo WHERE userid-'".$userid."'"; 
$user s-$user-»select($sql u); // 获 取 用 户 信和 
$sql c-"SELECT * FROM usercard WHERE userid- $userid."'"; 
$user c-$user-»select($sql c); // 获 取 用 户 购书 卡 信息 

$fm=0; ”// 标 识 用 户 是 否 可 用 购书 卡 购书 :1 一 不 可 用 ; 0 一 可 用 

if (count ($user_c)==0) $fm=1; // 用 户 无 购书 卡 

else(  // 用 户 有 购书 卡 


$cardtotal=0; 
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for ($i=0;$i<count ($user_c);$i++) { // 统 计 用 户 购书 卡 的 金额 
$sql-"SELECT * FROM card WHERE cardno='".$user c[$i]['cardno']."'"; 
$card s-$user-»select ($sql); 
if($cardtotal«$total) $cardtotal*-$card s[0]['balance']; 
) 
if($cardtotal«$total) $fm=1; // 用 户 购书 卡 的 金额 不 足以 支付 此 次 购书 
) 
$sf-new control(); 
$sql f-"SELECT * FROM order fmoney"; 
Sorder f-$sf-»select($sql f); // 获 取 付 款 方式 信息 
$sql s-"SELECT * FROM order send"; 
$order s-$sf-»select($sql s); // 获 取 送 书 方式 信 
?» 


息 





<tr><td colspan-"7" class-"tdl"» 

功能 打印 出 订 
</table> 

<script language-"JavaScript" type-"text/javascript"» 





:在 填写 完 订 单 后 ， 请 用 浏览 器 的 打印 





a </td></tr> 


function is_OK(){ 

var usernamel-document.frm.username.value; 

var postl-document.frm.post.value; 

var addrl-document.frm.addr.value; 

var phonel-document.frm.phone.value; 

var emaill-document:frm.email.value; 

if (usernamele-"")( 
window.alezt(" 联 系 人 不 能 为 空 ") ; 
document.frm.userid.focus(); 

) 

else if(postl--"")( 
window .alert ("邮编 不 








document.frm.password.focus(); 
) 

else if(addrl--"")( 
window.alert ("地 址 不 能 





document.frm.password.focus(); 

n 

else if(phonel--"")( 
window.alert ("联系 电话 号 码 不 能 为 空 ") ; 
document.frm.password.focus(); 

Dn 

else if(emaill- 
window.alert( 








"){ 
电子 邮箱 不 能 为 


document.frm.password.focus(); 





) 
</script> 
<table width-"600" border-"1" cellspacing="1" class-"tdl"» 
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«form method-"POST" name 

<tr><td id= 
</td></tr> 

<tr><td align=right> A: </td> 





"frm" action="order_p.php" 
><?php echo userid; 








bb" colspan=" 





<td><input type="text"size="60" name="username" value="<?php 
echo $user s[0] ['username'] ; ?>" /»«/td»«/tr» 
<tr><td align="right"> 邮 编 : «/td» 
<td><input type-"text"size-"60" name-"post" value-"«?php echo 
$user s[0] ['post'] ;?»"/»«/td»«/tr» 
«tr»«td align="right"> 地 址 : «/td» 
<td><input type="text" name="addr" size="60" value="<?php echo 
$user s[0] ['addr'];?»" /></td></tr> 
<tr><td align="right"> 电 话 号 码 : </td> 
<td><input type="text" name-"phone" size-"60" value-"«?php echo 
$user s[0] ['phone'];?»" /»«/td»«/tr» 
<tr><td align="right"> 电 子 邮件 ，</td> 
<td><input type="text" name-"email" size="60" value="<?php echo 
$user s[0] ['email'];?»"/»«/td»«/tr» 
«tr id-"bb"»«td align-"right"53E357j:: «/td»«td» 
«?php 
for($i-0;$i«count($order s);$i4«)| // 设 置 单 选 按钮 组 ， 让 用 户 选择 送 书 方式 
echo '<input name-"sendb".type-"radio" value="' .Sorder s[$i]['send id']; 
if ($i==0) echo '".óhecked-"checked" /为 和 else echo '" /»' 
echo $order s[$i]['send name']; 






?» 
«/td»«/tr»«tr class-'tdl'»«td'colspan-"2"» 送 书 方式 简介 : <br/> 

<?php 
for($i=0;$i<count ($order_s); $i++) // 显 示 各 种 送 书 方式 F 


echo ($i+1).".".$order s[$i]['send con']."«br /»"; 


介绍 





?> 
«/td»«/tr»«tr id-"bb"»«td align="right"> 付 款 方式 : </td><td> 

<?php 
for ($i=$fm; $i<count ($order f);$i++){  // 设 置 单 





选 按钮 组 ， 让 用 户 选择 付款 方式 
echo '«input type="radio" name-"pay" value-"'.$order f[$i]['fmoney 
name']; 





if(Si--$fm) echo '" checked-"checked" />'; else echo '" /»'; 
echo $order f[$i]['fmoney name']; 


?> 
</td></tr><tr class-'tdl'»«td colspan="2"> 付 款 方式 简介 : «br/» 
«?php 
for(S$i-$fm;$i«count(Sorder f);$i++){ // 显 示 各 种 付款 方式 的 简单 介绍 
if ($fm==1) echo Si; else echo ($i+1); 
echo ".".$order f[Si]['fmoney name']." 
«br /»"; 






".Sorder f[Si]['fmoney con']." 


W 
Ul 
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2» 

«/td»«/tr»«tr id-"bb"»«td align-"center" colspan-"2"» 

«input type="button" value=" 放 弃 " onclick-" window.close()" /> «input 
type="submit" name-'act' value=" 确 定 ” onmouseover-"is OK();" onclick-"window. 
close()" /» «/td»«/tr» 

</form> 
</table> 
<div id="bb"><?php echo $msg; ?></div> 
</div> 
</body> 
</html> 


(3) 把 文档 以 book_order.php 为 文件 名 保存 在 webshop 文件 夹 下 


v" 


book order.php 用 于 显示 选 购 图 书 的 详细 信息 及 配送 信息 、 送 书 方式 、 支 付 方式 和 相关 提示 信息 
便 用 户 对 订单 的 确认 .这 段 代码 中 使 用 了 多 个 数据 表 : -从 数据 库 member 的 数据 表 usercard, card 中 提取 
用 户 购书 卡 和 卡 内 的 数据 ， 以 判断 用 户 是 否 具有 购书 卡 支付 资格 ; 数据 表 userinfo 提供 了 用 户 的 基本 信息 
供 送 书 联系 之 用 。bookcart 提供 用 户 选 购 图 书 的 信息 ,order_send 提供 了 详细 的 送 书 方 # 
提供 了 详细 的 付款 方式 信息 ,由 于 用 户 在 确认 时 可 能 会 修改 其 中 的 数据 ， 因 此 使 用 表单 
户 确认 和 修改 ， 还 使 用 JavaScript 对 表单 输入 做 初步 检查 。 
第 45 一 48 行 : 输出 用 户 选 购 图 书 的 相关 信息 并 记录 选 购 图 书 的 书号 和 数量 。 其 中 : 
第 46、47 行 : 记录 选 购 图 书 的 序列 号 和 数量 。 用 喜 号 (和 在 前 分 害 ， 用 函数 explode0 分 离 时 ， 有 效 
数据 从 D 开始 。 这些 数 据 将 记录 在 数据 表 orderinfo 的 字段 order note 中 以 备 订单 查 
MEEA. 
第 49 行 : 计算 本 次 购书 的 总 金额 。 
第 54~55 4p. 把 数据 存放 在 全 局 变量 S_ SESSION 中 ， 便 于 页 面 间 的 数据 传递 和 使 用 。 
第 61 一 72 行 : 获取 和 处 理 要 用 户 确 认 的 配送 信息 。 获取 用 户 信 息 用 于 显示 在 输入 表单 中 ; KRAP 
的 购书 卡 以 确定 卡 内 金额 是 否 足以 支付 本 次 购书 ， AT REUSS ERAT NTITM 
PERAH, Sfm 初 值 设置 为 0 表示 可 用 购书 卡 支付 ， 这 与 其 后 的 支付 方式 选择 相对 应 。 
第 123 一 135 行 : 以 单 选 按钮 表单 显示 送 书 方式 选择 ， 其 中 默认 为 第 一 个 。 
第 136 一 150 行 : 以 单 选 按钮 表单 显示 付款 方式 选择 ， 其 中 默认 为 第 一 个 。 注 意 ， 购 书 卡 支付 是 否 可 
用 ， 取 决 于 $fm E57 0. 












order_fmoney 
显示 其 值 方便 用 





(4) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(5) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 

















«?php 
Gsession start(); // 启 动 会 话 
$msgl=""; $userid="";$sub=""; $b id="";$b num=0;$b money-0.0; 
$button=" 确 定 "; 


if(isset($ SESSION['userid'])) $userid-$ SESSION['userid']; 
if(isset($ POST['act'])) $sub-$ POST['act']; // 获 取 用 户 对 前 一 页 的 操作 
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if ($sub==" 放 弃 ") { ” // 用 户 放弃 本 次 购书 的 反馈 信息 和 操作 设置 
$msgl=$userid. ' :确定 要 放弃 吗 ? WHE! <br/> 单 击 “ 确 定 ”按钮 后 ， 将 清除 购物 车 上 
的 所 有 信息 。 ' 
$url-"cart clear.php"; 
5 
else if($sub==" 确 定 "){ // 用 户 确认 本 次 购书 的 反馈 信息 和 操作 设置 





if(isset($ SESSION['b id'])) $b id-$ SESSION['b id']; 
if(isset($ SESSION['bk num'])) $b num-$ SESSION['bk num']; 
if(isset($ SESSION['b money'])) $b money-$ SESSION['b money']; // 获 取 SESSION 
变量 
if(isset($ POST['username'])) $username-$ POST['username']; 
if(isset($ POST['post'])) $postl-$ POST['post']; 
if(isset($ POST ['addr'])) Saddrl-S POST ['addr']; 
if(isset($ POST['phone'])) $phonel-$ POST[ 'phone "5 
if(isset($ POST['email'])) $emaill-$ POST['email']; 
if(isset($ POST['sendb'])) $send-$ POST['sendb']; 
if(isset($ POST['pay'])) Sfmoney-$ POSTI'pay']; // 获 取 提交 的 表单 信息 
if ($fmoney==" 购 书 卡 支付 ") {  // 对 购书 林 支 付 的 处 理 
require once('include/user.inc.php'); 
Suser-new user(); 
$search u-"UPDATE userinfo SET username-'".$username."',email-'". 


$emaill."',addr-'".$addrl."',.post-'".$postl."',phone-'".$phonel."' WHERE 
userid-'".$userid."'"; - 
$user s-$user-»update(Ssearch u); //3XkNUn fs 
$search s-"SELECT'* FROM usercard WHERE userid-'".S$userid."'"; 
$user s-$user-»select($search s); //3KMUT PAA 
Smsg1.=$ugeEia."， 您 采用 购书 卡 支付 ， 已 结 清 书 款 ! <br/>"; 
$j-0; $p money-$b money; ,六 /备份 本 次 消费 金额 
while(Sp money>0 && $j«count(Suser s))|( // 扣 除 购书 卡 本 次 消费 的 金额 
‘$sql c-"SELECT * FROM card WHERE cardno-'".$user s[$j]['cardno']. E 
$card s-$user-»select($sql c); 
if($card s[0]['balance']»-$p money) ( // 一 张 购书 卡 能 支付 本 次 消费 的 金额 
$cards-$card s[0]['balance']-$p money; // 扣 除 本 次 消费 的 金额 
$p money-0; // 尚 未 付费 金额 设置 为 0 
$search c-"UPDATE card SET balance=$cards WHERE cardno-'".$user s[$j] 
['cardno']."'"; 
$cardu-$user-»update($search c); // 更 新 购书 卡 的 余额 
$msg1 .=" 购 书 卡 " .$user_s[$j] ['cardno'] ." 内 余额 ".Scards."«br/» <br/>"; 
} 
else( // 一 张 购 书 卡 不 足以 支付 本 次 消费 的 金额 
$p money-$p money-$card s[0]['balance']; // 设 置 尚未 付费 金额 为 0 
Smsgl .=" 购 书 卡 ".S$user_s[$j] ['cardno']." 内 已 无 余额 <br/><br/>"; 
$search c-"UPDATE card SET balance-0 WHERE cardno-'".$user s[$j] 
['"cardno!] ums. 
$cardu-$user-»update($search c); // 设 置 该 购书 卡 的 金额 为 0 
$jtt; 
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} 
require once('include/control.inc.php'); 
$bcob-new control(); // 创 建 订单 对 象 





$sql f-"SELECT * FROM order fmoney WHERE fmoney name-'".$fmoney."'"; 
$fmoney id-(int)S$bcob-»select($sql f)[0]['fmoney id']; 
$sql o-"INSERT INTO order info(user name,order post,order addr,order 





phone,order mail, order send,order fmoney,order num,order state, order money, 
order time,order note) VALUES('S$username',' '$postl','$addr1l','$phonel', 
'S$emaill','$send','$fmoney id','$b num','0','$b money',CURRENT TIMESTAMP, 
'$b id')"; 
$order o-(int)$bcob-»insert($sal o); // 生 成 一 个 新 订单 ， 返 回 的 是 该 记录 的 序列 号 ， 
作为 订单 号 









$sql c-"UPDATE book cart SET order id-'".$order o."' WHERE user id 
-'".$userid."'"; 
$cart c-$bcob-»update($sql c); // 修 改 购书 车 的 azder_ID 





$msg1.=$userid.": 恭 喜 您 ， 购 书 成 功 !<br/> 您 的 订单 号 为 : ".$order_o; 
$button=" 查 看 订单 详细 内 容 "; 
$url-"order.php?order id=".$order 0; 
$bcob-»closedb(); 
D 
?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmins-"http://www:w3.0rg/1999/xhtml"» 
<head> 
«meta http-equiv="Content-Type" content-"text/html; charset=utf-8"> 
<base target-"mainFrame"» 
<title> 订 单 信息 确认 </title> 
«link href-"css/bscss.css" rel-"stylesheet" type-"text/css" /> 
</head> 
<body> 





<div id="appb"> 
<div id="bt"> 确 认 订 单 信息 <hr/></div> 
<div id="bb"><?php echo $msgl; ?></div> 
<div align="center"> 





«form action="<?php echo $url; ?>" method="post" target="_blank"> 
<input type="submit" value="<?php echo $button; ?>" /> 
<?php if ($button==" 查 看 订单 详细 内 容 "){ ?> 

<a href="exit.php" target="mainFrame" ><input type="button" value=" 
完成 购书 "” /></a></form> 
<?php } 
else (?» 

«a href-"book order.php" target-" blank" »«input type-"button" value-" 
返回 " /></a></form> 
<?php } 
?» 
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«/div» 
«/div» 
</body> 
</html> 





(6) 把 文档 以 order_p.php 为 文件 名 保存 在 webshop 文件 夹 下 。 


人 Moen 


order | p.php 用 于 处 理 用 户 对 订单 的 确认 。 放 弃 订单 就 清除 购物 车 ， 确 认 订单 就 生成 订单 号 并 把 相关 
数据 写 入 数据 表 orderinfo。 
$4 64: 获取 用 户 对 前 页 的 操作 ， 单 击 了 “放弃 ”按钮 还 是 单 击 了 “确定 ”按钮 。 
第 7 一 10 行 : 对 单 击 “放弃 ”按钮 的 处 理 ， 即 设置 反馈 信息 、 本 页 提交 按钮 的 名 称 和 表单 处 理 程序 。 
第 11 一 62 行 : 对 单 击 “确定 ”按钮 的 处 理 ， 即 处 理 写 入 数据 表 的 数据 汇 将 数据 插入 数据 表 、 设 置 反 
锁 信 息 、 本 页 提交 按钮 的 名 称 和 表单 处 理 程序 .《 其 中 
第 22 一 50 fr: 对 使 用 购书 卡 支付 的 数据 处 理 。 
第 23 一 29 行 : 获取 用 户 所 有 购书 卡 的 信息 。 
第 31 一 49 行 : 扣除 本 次 购书 金额 ， 修 改 卡 内 的 伦 额 六 设置 反馈 信息 。 
第 32 一 33 41: 获取 该 用 户 的 一 张 购书 有 。 
第 34 一 40 行 : 该 张 卡 能 支付 本 次 购书 金额 ， 就 扣除 相应 的 金额 ， 未 付 金 额 设 为 0， 修 改 卡 内 
的 余额 ， 
第 41 一 48 行 : 该 张 卡 不 能 支 件 本 次 购书 金额 ， 就 计算 出 未 付 金 额 ， 修 改 卡 内 的 余额 为 0。 
第 51—57 行 : 插入 一 条 新 记录 到 数据 表 orderinfo。 字 段 ,order_note 记录 了 订单 中 各 本 书 的 书号 和 
数量 。 
第 55，57 行 : 返回 值 是 当前 记录 的 序列 号 , 用 它 作 为 订单 号 . 
第 78 行 : 设置 用 户 的 操作 ， 根 据 前 面 的 设置 来 确定 按钮 的 名 称 和 处 理 程序 。 
第 79 一 81 行当 确定 用 户 确定 表单 时 ， 再 添加 “购书 完成 ”按钮 ， 通 过 超 链接 实现 页 面 更 新 。 
第 82 一 85 行当 确定 用 户 放弃 表单 时 ， 添 加 “返回 ”按钮 ， 通 过 超 链接 实现 页 面 更 新 。 


(7) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(8) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
$userIP-$ SERVER['REMOTE ADDR']; // 获 取 用 户 的 IP 地 址 ， 以 识别 用 户 
require once('include/control.inc.php');  // 请 求 包含 相应 类 的 文件 
Sbcob=new control(); // 创 建 购物 车 对 象 


$sql-"DELETE FROM book cart WHERE cart session id -'".S$userIP."'"; 

$bcob-»delete ($sql); 

$sql-"ALTER TABLE book cart DROP cart ID"; 

$bcob-»delete ($sql); 

$sql-"ALTER TABLE book cart ADD cart ID INT(11) NOT NULL AUTO INCREMENT 
PRIMARY KEY FIRST;"; 

$bcob-»delete ($sql); 

echo "<meta http-equiv-'Refresh' content-'0;url-../main.php'»"; 
id 
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(9) 把 文档 以 exit.php 为 文件 名 保存 在 webshop 文件 夹 下 。 
3. 查询 订单 
代码 文件 : order. search.php. 


(1) 在 Dreamweaver 中 ， 新 建 PHP X 
(2) 单 击 “ 代 码 ” 标 


<?php 
$msg=""; $orderID=""; $username=""; $email=""; $sub=""; 
if(isset($ POST['orderID'])) $orderID-$ POST['orderID']; 
if(isset($ POST['username'])) $username=$ POST['username']; 
if(isset($ POST['email'])) S$email-$ POST['email']; 
if(isset($ POST['set'])) $sub-$ POST['set']; 
if ($sub--"frifj") ( 
require once('include/control.inc.php');/ MX 请 求 包含 相应 类 的 文件 
$order=new control(); /7 创建 订单 对 象 
SorderID."' ORWuSser’ name -'".$username."' OR 








T 
， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 





$search=" (order_id: 
order mail-'".S$email. 

$DTname-"order info"; 

$order s-$order-»GetDTdataset($DTname,$search);  // 获 取 指定 条 件 的 订单 信息 

Sorder-»closedb(); 

if(count(Sorder s)«1 ) Smsg=" 没 有 符合 查询 条 件 的 订单 ! "7 

else 

echo "«meta http-equiv-'Refresh' content-'0;url-order list.php?page- 





l&&order id-".$orderID."&&username-".$username."&&email-".S$email."'/»"; 
) 
?» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title> 订 单 查询 信息 </title> 
<link href="css/bscss.css" rel="stylesheet" type="text/css" /> 





«script language="JavaScript"> 
function tjpd()( 
var orderIDl-window.frm.orderID.value; 
var usernamel-window.frm.username.value; 
var emaill-window.frm.email.value; 
if(orderID1--"" && usernamel- && emaill--"")( 
window.alert (" 必 须 输入 一 个 条 件 ! ") 7 


window.frm.orderID.focus(); 








) 
</script> 
</head> 
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<body> 
<div id="appb"> 
«div id="bt"> 查 询 订单 <hr/></div> 
«table width-"600" border="0" cellspacing="0" class-"tdl"» 
«tr»«td id="bb"> 请 确认 查询 条 件 </td></tr> 
</table> 
«form name-"frm" action-"order search.php" target-"mainFrame" method= 
"post"» 
«table width-"600" border-"1" cellspacing-"1" class-"tdl"» 
<tr><td align="right"> 订 单 号 : </td> 
<td><input name-"orderID" type="text" size="20"/>&nbsp;&nbsp; 或 者 
</td></tr> 
<tr><td align="right"> 订 单 联系 人 : </td> 
<td><input name-"username" type-"text" size-"20"/»&nbsp; &nbsp; 
或 者 </td></tr> 
<tr><td align="right"> RAM: </td> 
<td><input name="email" type-"text" size-"20"/»«/td»«/tr» 
<tr><td colspan="2" align-"center"»«input name-"set" type="submit" 
value=" 查 询 " onmousedown-"tjpd()" /»&nbsp;«Xinput type="reset" value=" XE" /> 
</td></tr> 
</table> 
</form> 
«div id="bb"><?php echo $msg; ?></div> 
«/div» 
</body> 
</html> 





(3) 把 文档 以 order_search.php 为 文件 名 保存 在 webshop 文件 夹 下 。 


C TEN 


order. search.php 用 于 设置 查询 订单 页 面 的 显示 和 处 理 。 查询 条 件 可 以 是 订单 号 、 联 系 人 、 邮 箱 地 址 之 
一 ， 符 合 条 件 的 订单 存在 就 转 到 order list.php. 
第 1 一 18 行 : 对 表单 提交 后 的 处 理 ， 即 首先 获取 提交 表单 的 数据 ， 接 着 组 织 查 询 条 件 并 在 表 orderinfo 
中 查询 符合 查询 条 件 的 记录 ， 由 此 判断 订单 是 否 存在 来 确定 是 给 出 反馈 信息 还 是 转 到 
order list.php. 
第 41 一 54 行 : 以 表格 的 方式 组 织 查询 表单 ， 处 理 程序 是 自身 。 


4 显示 订单 列表 

代码 文件 :order list.php 

(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 

(2) 单 击 “ 代 码 ” 标 切换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


a o 
2 $orderID-""; $email 




















;Spage-0;$username-''; 
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if(isset($ GET['order id'])) $orderID=$ GET['order id']; 
if(isset($ GET['username'])) $username=$ GET['username']; 
if(isset($ GET['email'])) $email-$ GET['email']; 
if(isset($ GET['page'])) $page-$ GET['page']; 

if(isset($ POST['page'])) $page=$ POST['page']; 


if ($page<1) $page-1; 

require once('include/control.inc.php'); 

require once ('include/display.inc.php'); 

Sorder-new control(); // 创 建 订单 对 象 

$search=" (order id-'".$orderID."' OR user name -'".$username."' OR 
order mail-'".$email."')"; 

$DTname-"order info"; 

Sorder s-$order-»GetDTdataset ($DTname,$search);  // 和 获取 指定 条 件 的 订单 信息 

Sorder-»closedb(); 
$url="order list.php?orderID-".$orderID."&&username-".$username." 
&&email-".Semail."&&page-"; 

$displayorder-new display(Sorder s,$order-» pageSize); 

$displayorder-» pageSize-$order-» pageSize; // 统 一 显示 页 与 数据 分 页 的 行 数 

$pagelast=$displayorder->GetpageNum($order_s); // 提 取 显 示 的 最 后 页 码 
$orders-$order-»GetControlList(Sorder s,$page); // 提 取 当 前 页 的 显示 数据 
$displaybar-$displayorder-»GetJumpBar($order s,$page,$url); // 生 成 分 页 导 

航 栏 信息 





?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML.1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlnsz"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv-"Content-Type" content="text/html; charset-utf-8"» 
<titTJe> 订 单 信息 </tit1le> 
«link href-"css/bscss.css" rel-"stylesheet" type-"text/css" /> 
</head> 
<body> 
<div id="appb"> 
«div id="bt"> 订 单列 表 信 息 <hr/></div> 
«table width-"600" border="0" cellspacing="0" class-"tdl"» 
«form action-"«?php echo $url. ($page) ; ?»" method="post" target-" self"» 
<tr><td > 共有 <?php echo count(Sorder s); ?> 个 订单 anbsp; &nbsp; Jt«?php 
echo $pagelast; ?> 页 &nbsp;&nbsp;<?php echo $displaybar['JumpBar'];?></td> 
right"> 输入 页 
«input type-"submit" name-"send2" value=" 转 到 " /> </td></tr></form> 
</table> 
«table width-"600" border-"1" cellspacing-"1" class-"tdl"» 
«tr align="center" id-"bb" ><td> 序 号 </td><td> 订 单 号 </td><td> 联 系 人 </td> 
<td> 定 书 数量 </td><td> 总 价格 </td><td> 订 单 状态 </td><td> 创 建 时 间 </td> 
<td> 详 细 </td></tr> 





«td align 





; <input type="text" size-"3" name-"page"^ 
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«?php 
for($j20;$j«count (Sorders);$j**)( 
if(Sorders[$j]['order state']--1) $state=" 完 成 "; 
else{ 


if(Sorders[$j]['order fmoney']--1) $state=" 已 付费 ,配送 中 "; 
else $state=" 配 送 中 "; 
} 
SorderID-$orders[$j]['order ID']; 
echo "<tr algin-'center'»«td»". ($j41)."«/td»"; 


echo "«td»".$orderID."«/td»«td»".$orders[$j]['user name']." </td>"; 
echo "«td»".S$orders[$j]['order num']." «/td»«td»".$orders[$j]['order 
money']." «/td»"; 


echo "«td»".$state."«/td»«td»".$orders[$j]['order time']."«/td»"; 
echo "<td><a href-'order.php?order id-$orderID' target-' blank'> 查 
fi«/a»«/td»«/tr»"; 
) 
?> 
<tr><td colspan-"8" align-"right"»«?php echo $displaybar['msg']; ?> 
«/td»«/tr» 
Stud 





"bb"»«td align-"left" colspan="8"> 提 示 : 单 击 “ 查 看 ”链接 可 以 查 
9 详细 情况 。</td></tr> 
</table> 
</div> 
</body> 
</html> 


(3) 把 文档 以 order_list.php 为 文件 名 保存 在 webshop 文件 夹 下 。 





mira 





é 
E MY TIT 


order list.php 采用 分 页 显示 技术 ， 列 出 了 查询 的 所 有 表单 ， 页 面 布 局 与 book_show.php X4 





信息 


5. 显示 订单 
代码 文件 : orderphp 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “ 代 码 ” 标 切换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
$orderID=0; 
if (isset ($_GET['order_id'])) $orderID=$_GET['order_id']; 
require once('include/control.inc.php'); 
$order-new control(); // 创 建 订单 对 象 
$DTname="order info";$search="order id='".$orderID."'"; 
$order s=$order->GetDTdataset ($DTname, $search); ”// 获 取 和 制定 订单 号 的 订单 
$book s=explode(":",$order s[0]['order note']); // 分 离 出 图 书 的 序列 号 和 : 
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$book IDS-explode (",",$book s[0]); // 分 离 出 各 本 图 书 的 序列 号 
$book nums-explode (",",$book s[1]); // 分 离 出 各 本 图 书 的 数量 
?» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title> 订 单 信息 </title> 
<link href="css/bscss.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="appb"> 
«div id="bt"> 订 单 信息 <hr /></div> 
«table width="100%" border="0" cellspacing-"0" class-"tdl"» 
<tr><td id="bb"> 订 单 号 ，<?phP echo $orderID;?»«/td»«/tr» 
<tr><td> 共 有 <?php echo $order s[O0]['order num'];?»4kji«/td»«/tr» 
</table> 
<table width="100%" border=!1"\ĉèėllspacing="1" class="tdl"> 
<tr align="center" id="bb"><tdwidth="30%"> 书 名 </td><td width="30%"> 
作者 </td> 
<td> 包 装 说 明 </td><td> 出 版 社 </td><td> 价 格 </td><td> 购 买 数量 </td><td> 合 计 
«/td»«/tr» 





«?php 
$book=new control(); 
for($j-0;$j«Sorder s[0]['order num'];$j**)1 // 输 出 各 本 图 书 的 信息 


$search b-"SELECT * FROM book info WHERE book id-'".$book IDS[$j]."'"; 
$books-$book-»select ($search b); 


echo "<tr><td>" .$books [0] ['book name']."«/td»«td»".$books[0] ['author']. 
"«/td»"; 

echo "<td align-'center'»".$books[0]['book bs']."«/td»«td 
align-'center'»".$books[0] ['publisher']."«/td»"; 

echo "<td align-'center'»".$books[0]['price m']."«/td»«td align= 
'center'»". $book nums[$j]." </td>"; 

echo "<td align-'center'»".$books[0]['price m']*$book nums[$j]. "</td> 
«/tr»"; 


) 
echo "<tr id-'bb'»«td colspan-'5' align='right'> 书 款 总 额 </td>"; 


echo "<td colspan-'2'»".$order s[0]['order money']."&nbsp; &nbsp; 元 
«/td»«/tr»"; 

$DTname-"order send";$search-"send id-'".$order s[0]['order send']."'"; 

$order send-$order-»GetDTdataset ($DTname,$search); // 获 取 制 定 订单 号 的 订单 信息 

SDTname-"order fmoney";$search="fmoney id-'".$order s[0]['order_ 
fmoney']."'"; 


$order fm-$order-»GetDTdataset($DTname,$search); // 获 取 制 定 订单 号 的 订单 信息 
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$book->closedb (); 
?» 
</table> 
<table width-"100$" border= 
<tr><td id="bb" colspan: 






cellspacing="1" class-"tdl"» 
"> 配送 信息 : </td></tr> 
<tr><td colspan="2"> 联 系 人 : <?php echo $order_s[0]['user name'];?> 
</td></tr> 
<tr><td> 地 址 : <?php echo Sorder s[0]['order addr']; ?»«/td» 
<td> 邮 编 ; <?php echo $order s[0]['order post']; ?»«/td»«/tr» 
<tr><td> 电 子 邮 件 : <?php echo $order s[O0]['order mail']; ?»«/td» 
<td> 电 话 : <?php echo S$order s[0]['order phone']; ?»«/td»«/tr» 
<tr><td colspan-"2" id="bb"> 送 货 方式 : <?php echo $order send[0] ['send 
name']; ?» «/td»«/tr» 
<tr><td colspan-"2" id="bb"> 结 算 方式 ， <?php echo S$order fm[0]['fmoney 
name']; ?> «/td»«/tr» 
<tr><td colspan-"2" align="center" ids"bb"»«a href="#" onClick- 
"window.close();"»jR|uc/a»«/td»«/tr» 
</table> 
</div> 
</body> 
</html> 


(3) 把 文档 以 orderphp 为 文件 名 保存 在 webshop 文件 夹 下 。 








order.php 用 于 显示 用 户 确 认 后 的 订单 信息 、 页 面 布局 与 book_orderphp X4. 


1$ 


CUT" 8 (ir 
7.8.6 ”调试 代码 
l. 准备 测试 数据 


在 bookshop 数据 库 的 12 张 数据 表 中 ， 表 bookcart、orderinfo 和 usermessage 不 需要 准 
备 数据 ， 其 中 的 数据 是 在 运行 过 程 中 生成 的 。 而 其 他 表 需 要 准备 测试 数据 。 
K booktype 中 至 少 有 3 个 类 别 的 图 书 , 一 个 没有 子 类 别 ,一 个 有 多 个 子 类 别 。 表 bookclass 
至 少 有 5 个 数据 ， 其 中 一 个 至 少 有 4 个。 测试 数据 如 表 7.12 和 表 7.13 所 示 。 
3 7.12. x& booktype 中 的 数据 
book type id book type name 说 RB 
1 | 计算 机 | 有 6 个 子 类 别 
2 | | 无 子 类 别 
3 有 一 个 子 类 别 
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3 7.13. x& bookclass 中 的 数据 























book class id book class name book type id 
1 程序 设计 类 1 
2 网 络 技术 类 1 
3 图 像 处 理 类 1 
4 数据 库 技术 类 1 
5 人 工 智能 类 1 
6 软件 工程 类 1 
7 高 等 数学 3 





K bookinfo 中 需要 不 少 于 10 本 图 书 的 详细 资料 ,并且 一 类 图 书 至 少 有 9 本 以 验证 图 书 
列表 中 的 分 页 显示 功能 。 从 身边 找 一 些 图 书 ， 按 照 表 bookinfo 中 各 字段 的 要 求 ， 通 过 
phpMyAdmin 录入 所 有 数据 。 

在 phpMyAdmin 中 设置 推荐 图 书 表 bookrecommend 和 热卖 图 书 表 bookhot 中 都 至 少 有 
1 个 记录 、 特 价 图 书 表 booksale 中 有 1 个 记录 以 验证 main.php 中 的 数据 呈现 。 

表 order. fmoney 中 的 数据 是 固定 的 ， 其 内 容 如 表 7.14 所 示 。 


表 7.14 X order fmoney 中 的 数据 


fmoney_con 
对 于 电 请 了 购书 卡 的 会 员 ， 购 书 款 可 直接 从 中 扣除 
通过 SEDES 
适用 于 送 书 上 门 方式 ,- 当 而 结 清 书 款 
















fmoney_id 



















K order. send 中 的 数据 也 是 相对 固定 的 > 其 内 容 如 表 7.15 所 示 。 
表 7.15 S order send 中 的 数据 





send_con 
抽 为 市 区 ， 每 张 订单 运费 4 元 
2 | “特快 专递 “| 收费 标准 为 订单 金额 的 20%， 订 单 金额 等 于 或 低 于 50 元 时 按 20 元 收取 
3 | 平邮 | 每 张 订单 运输 费 ，4.5 元 
4 EIRE | 不 收取 任何 费用 
用 户 信息 和 购书 卡 数据 参照 第 5 章 的 会 员 管理 。 
2. 确认 程序 上 传 到 服务 器 
确认 本 章 所 编写 的 文件 已 存放 在 服务 器 访问 目录 (如 ci\AppservVwww\wuya 或 
htdocs\wuya) 的 根 目录 下 和 webshop 子 目录 下 。 
3. 在 IE 上 测试 代码 


1 xn 送 货 














io 


c: 








(1) JAZ TE 浏览 器 ， 输 入 http://localhost/wuya/index.php， 单 击 “ 转 到 ”按钮 ， 可 见 


如 图 7.12 所 示 的 效果 。 
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CAT) 


O 单 击 “ 分 类 查询 ”栏目 中 的 人 + 展开 二 级 菜单， us E^ E “-"， 再 单 击 “-"， 菜 单 被 
Ard EM *-" EAT "ess 说 明 实 现 了 TX onum 

Q “ARAE” 等 3 个 栏目 的 数据 都 正常 显示 php、 mnain php 等 文件 也 实现 了 预 设 的 功 
能 。 同 时 说 明 configinc. > db.inc.php 和 con line 常 有 效 。 


Q) a 栏目 中 Wood "2" 展开 二 级 菜单 ， 从 中 选择 “程序 设 
计 类 ”链接 ， 可 见 如 图 7.13 所 示 的 效果 。 
0 mcm e| y d 


ERR! SARNE | ATRAE | IER! 20EESO WZS) HSSE 
ADRE | SMES) NAME] Ries 
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图 7.13 分 类 查询 界面 
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© 


CAT 

中 leftnemu.php 中 的 链接 功能 正常 实现 。book_show.php 能 正常 显示 . 

© 进一步 测试 book_show:php: 单 击 导航 栏 上 的 “热卖 图 书 ” 等 4 个 链接 及 main.php 中 的 3 个 “更 多 ” 链 
接 ， 或 在 “图 书 搜索 ”栏目 中 设置 查询 条 件 (尤其 关注 出 版 日 期 )， 单 击 “ 查 询 ” 按 钮 ， 观 察 显示 是 否 正常。 

图 单 击 如 图 7.13 所 示 的 翻 页 导航 ， 观 察 变化 。 测试 display.inc.php 中 定义 类 的 功能 。 

图 单 击 “分 类 查询 ”栏目 中 的 “文学 ”链接 ， 观 察 界面 的 变化 。 


G) 单 击 图 7.13 中 的 最 右 侧 的 “详情 …” 链 接 ， 可 见 如 图 7.14 所 示 的 效果 。 


Piatha em a 
| | 











mone 








7.44 图 书 详情 界面 (部 分 ) 


®© 界面 对 应 文件 bookfullinfo.php。 与 之 链接 的 还 有 图 7.12 中 的 图 书 图 片 。 
© 在 如 图 7.14 所 示 的 界面 下 方 是 用 户 对 该 书 的 评价 和 反馈 信息 。 输 入 用 户 名 、 选 择 “ 评 价 等 级 ”并 
写 一 段 评 价 内 容 ， 提 交 后 ， 可 见 如 图 7.15 所 示 界 面 的 变化 。 这 里 测试 的 是 user_fback.php 的 功能 


访客 评价 信息 





ET 














用 记名 
wen ORF 





sans 














图 7.15 用 户 评书 反馈 界面 


© 单 击 “ 返 回 ” 链 接 ， 将 关闭 这 个 界面 ， 回 到 进入 前 的 界面 。 
(4) 在 图 7.13 所 示 的 界面 中 ， 选 中 某 行 第 一 列 的 复 选 框 ， 并 在 “购买 数量 ”文本 框 中 




















输入 数据 ， 再 单 击 “ 放 入 购物 车 ”按钮 ， 可 见 如 图 7.16 所 示 的 效果 。 


购书 反馈 信息 








7.16 ”购书 反馈 界面 -有 效 


(D) 界面 对 应 文件 cart add.php. i 

O 在 图 7.13 P, CRAP HEHLIUAIE, Rd HO BALA Mein TAG Ad MULA CR 
购 任何 图 书 "; 没有 填写 数据 ， 就 单 击 “ 放 入 购物 车 按钮 "， 图 TRR 是 “所 选 图 书 S 的 购买 数 
量 应 该 为 正 整 数 1”. A 

G X hind" di, WEAR. AN、 


N 
(5) 在 如 图 7.16 所 示 的 界面 中 ， i ML. ”按钮 ， 可 见 如 图 7.17 所 示 的 效果 。 

















SUNL nad Imm 


Dpesmepmd gum 
Eu Ree — Reis — E 
i] 


SL ee EG 


图 7.17 “查看 购物 车 界面 





S un 

© 界面 对 应 文件 cart_check.php。 界面 还 可 验证 添加 购物 车 是 否 成 功 。 

© 在 图 7.13 中 添加 多 个 图 书 ， 测 试图 7.17 界面 的 分 页 显示 功能 。 

@ top.php 中 的 “查看 购物 车 ”链接 也 能 进入 如 图 7.17 所 示 的 界面 。 

(6) 在 图 7.17 所 示 的 界面 中 ， 选 择 某 个 复 选 框 ， 或 修改 文本 框 中 的 数据 ， 再 单 击 “ 修 
改 ” 按 钮 ， 可 见 如 图 7.18 所 示 的 效果 。 


CD 界面 对 应 文件 cart. update.php. 

Q 在 图 7.17 中 ， 如 果 没 有 选中 任何 复 选 框 ， 就 单 击 “修改 ”按钮 ， 图 7.18 给 出 的 反馈 是 “没有 选择 
修改 的 方式 1”; 当 填写 数据 非 正 整数 时 ， 图 7.18 给 出 的 反馈 是 “所 选 图 书 6 的 购买 数量 应 该 为 正 整数 1"。 

图 单 击 “返回 ”按钮 ， 回 到 查看 购物 车 界面 。 


(D) 单 击 导航 栏 中 的 “清空 购物 车 ”链接 ， 可 见 如 图 7.19 所 示 的 效果 。 
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修改 购书 信息 清空 购物 车 反馈 信息 
所 选 图 荐 3 修改 成 功 ! 风物 车 项 要 青空 
RBGHERSDIDSRUANAC 购物 车 中 选 购 的 7 本 图 书 尚未 生成 订单 | 

图 7.18 修改 购书 信息 界面 图 7.19 清空 购物 车 反馈 界面 


«P a "5 

CD. 界面 对 应 文件 cart_clearphp。 

© 单 击 “ 确 定 ”按钮 ， 图 7.19 给 出 的 反馈 是 “购物 车 已 清空! 购物 车 中 没有 选 购 的 图 书信 息 !”; 
购物 车 上 没有 图 书信 息 时 ， 单 击 导 航 栏 中 的 “清空 购物 车 ”链接 ， 图 7.19 给 出 的 反馈 是 WERDE 
物 车 中 没有 选 购 的 图 书信 息 !. 

© 在 图 7.19 中 ， 单 击 “ 查 看 购物 车 ”按钮 ， 放 弃 清空 购物 车 操作 ， 回 到 查看 购物 车 界面 。 





(8) 在 如 图 7.17 所 示 的 界面 中 ， 单 击 “ 下 订单 ”按钮 ， Me 图 7.20 所 示 的 效果 。 


下 订单 反馈 信息 


usua 
确定 要 购 天 书 车 上 的 图 | 
xm ar 
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87.20 下 订单 反 人 界面 
Lun AS 
(D 页 面 对 应 文件 order checkphp >S M XX 


© 当 购物 车 上 没有 图 书信 息 时 E720 给 出 的 反馈 是 “ Mk ERAT. 不 能 下 订单 !*， 下 方 有 
“返回 主页 ”按钮 ， 单 击 它 返回 才 页 DDR PER HRS 120 所 示 给 出 的 反馈 是 “还 没有 登录 ! 请 
BAER”, TFA “EA -按钮 ， 单 击 它 进入 登录 注册 面 。 


(9) 在 图 7.20 Wisin b. ik tpe" dug up fS 7.21 所 示 的 效果 。 
A 
1 j 


俩 认 订单 信息 
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7.21 订单 确认 界面 
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(D 界面 对 应 文件 book_orderphp。 单 击 下 方 的 按钮 将 对 应 文件 order. p.php. 

© 左边 图 中 的 配送 信息 需要 填写 ， 和 否则 会 跳出 警示 框 提醒 输入 ， 这 里 输入 的 信息 也 会 更 新 用 户 表 
(member.userinfo) 中 对 应 的 字段 。 当 购书 卡 不 可 用 时 ， 将 屏蔽 付款 方式 的 购书 卡 支付 。 

© 当 单 击 下 方 的 “放弃 ”按钮 时 ， 出 现 如 图 722 所 示 给 出 的 反馈 信息 ， 再 单 击 下 方 的 “确定 ”按钮 ， 
将 进入 如 图 7.20 所 示 的 清空 购物 车 界面 。 单 击 “ 确 定 ”按钮 ， 将 返回 如 图 7.21 所 示 的 界面 。 

图 当 单 击 下 方 的 “确定 ”按钮 时 ， 出 现 如 图 7.23 所 示 给 出 的 反馈 信息 。 





确认 订单 信息 





确认 订单 信息 





ege MASH TE 





广 à 
图 7.22 确认 订单 反馈 界面 -放弃 7.23、 确 认 订单 反馈 界面 -确定 
(10) 在 图 723 所 示 的 界面 中 ， 单 击 AN A” 按钮 ， 可 见 如 图 7.24 所 示 
的 效果 。 
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(D. 界面 对 应 文件 order.php. 
© 在 图 7.24 中 单 击 下 方 的 “返回 ”按钮 时 ， 返 回 图 7.23. 
© 单 击 图 7.23 下 方 的 “完成 购书 ”按钮 ， 执 行文 件 exit.php( 清 空 购书 车 ) 并 返回 主页 。 


(11) 单 击 导 航 栏 中 的 “查询 订单 ”链接 ， 可 见 如 图 7.25 所 示 的 效果 。 
Lun 
© 界面 对 应 文件 order_search.php. 


© 当 鼠 标 指针 指向 “查询 ”按钮 时 ， 出 现 警示 框 ， 提 示 “ 必 须 输 入 一 个 条 件 !”。 
© 当 输 入 的 条 件 无 效 时 ， 下 方 提示 “没有 符合 查询 条 件 的 订单 1” 


(12) 填写 一 个 有 效 条 件 ， 如 订单 号 ， 单 击 “ 查 询 ” 按 钮 ， 可 见 如 图 7.26 所 示 的 效果 。 
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图 7.25 查询 订单 界面 图 7.26 订单 列表 信息 界面 
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© 界面 对 应 文件 order_listphp。 
© 单 击 “ 查 看 ”链接 ， 可 见 如 图 724 所 示 的 订单 信息 界面 。 
© 尝试 生成 9 个 订单 ， 选 择 联系 人 查询 ， 观 察 图 726 分 页 显示 的 效果 。 
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7.4 PHP 面向 对 象 技术 
SS" 





741 基本 概念 


面向 对 象 编程 (Object Oriented Pr ”oop) 是 一 种 计算 机 编程 架构 ，OOP 的 一 
条 基本 原则 是 计算 机 程序 由 单个 能 够 起 到 于 程序 作用 的 单元 或 对 象 组 合 而 成 。 为 了 实现 间 
体 运算 ， ENAERE ARREARS AE 面向 对 象 一 直 是 软 
件 开发 领域 内 比较 热门 的 话题 克 首 先 ， 面 向 对 象 符合 大 类 看 待 事物 的 一 般 规律 ， 其 次 ， 采 

TO 采用 面向 对 象 方法 可 以 使 
其 编程 的 代码 更 简洁 更 易于 维护 ， 并 且 具 有 更 强 的 可 重用 性 
面向 对 象 编程 共有 三 大 特性 ; Me. Hi NUR. 
(1) 抽象 性 有 两 个 含义 ;抽象 性 是 使 具体 事物 一 般 化 的 过 程 ， 即 对 具有 特定 属性 及 行 
为 特征 的 对 象 进 行 概括 ， 从 中 提炼 出 这 一 类 对 象 的 共性 ， 并 从 通用 性 的 角度 描述 其 共有 的 
属性 及 行为 特征 。 抽 象 又 分 为 数据 抽象 和 代码 抽象 ， 数 据 抽象 描述 某 类 对 象 的 公共 属性 ， 
代码 抽象 描述 某 类 对 象 共有 的 行为 特征 。 
D 封装 性 是 一 种 数据 隐蔽 技术 。 有 着 个 含义 ， 一 是 把 对 象 的 全 部 属性 和 方法 结合 站 
一 起 ， 形 成 一 个 不 可 分 割 的 独立 单位 ( 即 对 象 );， 二 是 信息 隐蔽 ， 即 尽 可 能 隐蔽 对 象 的 内 间 
细节 ， 对 外 形成 一 道道 屏障 ， 只 保留 有 限 的 对 外 接口 与 外 部 联系 。 
O 继承 性 指 建立 一 个 新 的 派生 类 ， 从 一 个 或 多 个 先前 定义 的 类 中 继承 属性 和 方法 ， 
而 且 可 以 重新 定义 或 加 进 新 属性 和 方法 ， 从 而 建立 类 的 层次 或 等 级 。 

类 、 对 象 、 属 性 、 方 法 是 面向 对 象 技术 的 基本 概念 。 

QD 类 是 对 具有 相同 特性 (属性 ) 与 行为 (方法 ) 的 一 类 事物 的 抽象 描述 。 在 代码 中 表现 为 
关键 字 class 声明 的 一 段 代码 ， 其 内 部 包括 属性 和 方法 两 个 主要 部 分 。 

O 对 象 是 用 来 描述 客观 事物 的 一 个 实体 ， 它 是 构成 系统 的 一 个 基本 单位 。 在 创建 了 类 
之 后 ， 创 建 对 象 ， 其 特性 与 行为 由 所 属 类 的 特性 (属性 ) 与 行为 (方法 ) 决 定 。 在 代码 中 表现 为 
一 个 变量 ， 由 关键 字 new 创建 ， 通 过 -> 符号 获取 或 改变 它 的 特性 或 执行 某 种 行为 。 
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© 属性 用 以 表示 对 象 目前 的 状态 ， 以 变量 的 形式 定义 。 与 PHP 变量 的 使 用 方法 类 似 ， 
表现 为 形 如 “public$pro” 方 式 在 类 的 代码 中 定义 ， 通 过 “S$this->pro;” 或 “$ 对 象 名 ->pro;” 
的 方式 访问 它 的 值 。 
Lun 

在 PHP5 之 前 ,使 用 关键 字 var 定义 类 的 公共 属性 ， 也 就 是 说 属性 在 当前 整个 PHP 脚本 里 是 可 见 的 。 
在 PHP5 中 ， 不 提倡 使 用 关键 字 var, RAA public. 

(4) 方法 是 类 中 的 函数 ， 表 示 对 象 可 以 完成 的 一 系列 操作 ， 它 的 定义 方式 与 普通 PHP 
函数 一 致 ， 与 属性 一 样 ， 方 法 也 是 通过 -> 符号 来 访问 的 。 

属性 和 方法 被 称 为 类 的 成 员 。 




















示例 7-1 我 的 朋友 





“我 的 朋友 ”是 一 个 类 ， 它 不 表示 具体 的 一 位 朋友 ， 是 所 有 朋友 的 总 称 2 

姓名 、 性 别 、 年 龄 、 身 高 、 体 重 、 电 话 、 家 庭 住 址 是 “我 的 朋友 ”的 基本 信息 ( 届 性 )。 

开车 ， 会 说 英语 ， 可 以 使 用 计算 机 是 “我 的 朋友 ”能 做 的 事情 

“ 李 丽 ” 是 一 个 对 象 ， 它 是 一 位 具体 的 “朋友 ”。 

因此 ， 可 以 知道 她 的 姓名 、 性 别 、 年 龄 、 身 高 、 体 重 、/ 电 i 住址 等 ， 也 可 以 了 解 她 会 开车 ， 会 
说 英语 ， 可 以 使 用 计算 机 。 


s XN 
S un «RV 


PHP int RR SN Web 开发 语言 ， 它 对 OOP 的 支持 也 有 一 个 发 展 过 程 。 
PHP 4 以 前 的 版 本 是 一 种 面向 过 程 的 纺 PHP 4 引入 了 Morvan 的 是 过 程 模型 ， 只 是 兼 
面向 对 象 的 编码 写法 ， ur u ERROR oT ARDARA ERILE fat BAE. 例 
， 在 类 的 封装 方面 ， 可 以 法 等 访问 进行 限定 ; ; KAN 实现 机 制 方面 ， 使 用 类 接口 、 抽 象 类 及 
置 方法 ， 可 以 EDO 优化 对 象 处 理 流程 ， XN PHPS 面向 对 象 引擎 还 提供 十 余 个 可 以 实现 类 反 
射 的 对 象 。 ; 
在 PHP 5 环 } e PHP 4 标准 编写 的 程序 ， 但 按 PHP 5 标准 编写 的 程序 在 PHP 4 环境 
Vaid. R 面向 对 象 部 分 。 


74.2 定义 类 

l. 定义 类 的 语法 格式 
[final]classclassname{ // 定 义 类 
public[private[protected[static[const]]]$proteryl; // 定 义 属性 
// 定 义 方法 
[final]public[private [protected[static]]] functionmethodl (pal, —) {=}; 
)//end of class 

2. 限定 符 


从 限定 符 中 可 以 看 到 PHP 面向 对 象 的 特性 。 
(1) final 声明 方法 或 类 是 最 终 的 。 如 果 限 定 的 是 类 ， 则 该 类 不 可 继承 ; 如 果 限 定 的 是 方 
法 ， 则 该 方法 不 可 覆盖 。final 写 在 public. private. protected 之 前 。 





o 
A wx 网 上 购书 与 PHP 面向 对 象 技术 
6 T ed 


(2) public 声明 属性 或 方法 是 公开 的 。 在 任何 地 方 都 能 访问 到 ， 这 是 最 常用 的 限定 符 。 

(3) private 声明 属性 或 方法 是 私有 的 ， 只 有 在 定义 它 的 类 代码 中 使 

(4) protected 声明 属性 或 方法 是 被 保护 的 。 只 有 在 定义 它 的 类 或 其 派生 类 中 访 问 。 

(5) static 声明 属性 或 方法 是 静态 的 ， 可 以 直接 通过 classname::$pro 来 访问 属性 或 
classname::methodname() 来 调用 方法 , 而 不 必 创 建 对 象 。static 写 在 public. private, protected 
之 后 。 戎 态 成 员 有 许多 特别 之 处 ， 如 在 类 被 引入 时 就 被 执行 ， 而 不 是 要 等 到 对 象 声 明 ， 静 
态 属性 在 内 存 中 只 有 一 TR 而 不 是 为 每 个 对 象 都 分 配 一 个 地 址 。 

(6) const 声明 属性 是 常量 。 声 明 常 量 不 需要 $ 符 号 并 且 在 使 用 时 与 static 类 似 ， 如 通过 
classname::constpro 来 访问 ， 用 self::constpro 访问 类 内 部 的 常量 。 

3. 构造 与 析 构 

在 创建 对 象 时 需要 对 一 些 属性 进行 初始 化 ; 在 对 象 销毁 时 ， o 在 类 中 
这 两 种 函数 被 称 为 构造 函数 与 析 构 函数 。 

(1) 构造 函数 。 构 造 函数 _， etn 其 作用 是 将 对 象 调整 到 




































































“就 绪 ” 状 态 ， 以 供 程序 使 用 。 

(2) 析 构 函数 。 析 构 函数 _。 —— 其 作用 是 回收 资源 和 释 
放 内 存 。 
一 般 情况 下 , 对象 会 自动 销毁 ， — 所 有 对 象 都 被 自动 销毁 ， 
所 用 的 内 存 都 被 收回 。 WT 

另 一 种 情况 是 通过 调用 函数 来 显 起 地 销毁 对 象 即 航 发 析 构 函数 执行 。 

并 不 是 所 有 的 类 都 要 有 梅 i 函数 和 析 构 函数 ， 要 根据 实际 需要 来 确定 ， 若 不 需要 进行 
nin o ame 2 


Lun V R- x^ 
SN S 


在 PHP 4 PAXLA MR GE, (IER TOR construi, ASA EL £M adt: 没有 本 构 函 数 ， 
为 了 保持 兼容 性 ， 在 PHP 5 中 ， 如 果 类 中 没有 定义 构造 函数 ， 则 会 尝试 与 类 同名 的 函数 作为 构造 函数 ， 反 
过 来 ，PHP 4 不 能 将 _construct() 和 __destruct0 〇 识别 为 构造 和 析 构 函数 。(_ 是 两 个 ) 











示例 7-2 定义 
«?php 
class friends( 


// 下 面 是 朋友 的 成 员 属性 ， 都 是 封装 的 私有 成 员 





private $name; /7 朋友 的 姓名 
private $sex; // 朋 友 的 性 别 
private $age; // 朋 友 的 年 龄 
// 下 面 是 朋友 的 成 员 方 法 


function say(){ // 这 是 朋友 自我 介绍 的 方法 ， 可 以 访问 private 属性 
echo "我 的 姓名 : ".S$this-»name."fE5j. ".$this->sex. "年龄 ; ".$this->age. 
"Xbr»"; 
) 
private function run()( // 这 是 朋友 会 开车 的 方法 
echo "我 会 开车 "; 


AME TM t) 


a 


T 
// 定 义 构造 函数 ， 参 数 为 姓名 $name、 性 别 $sex 和 年 龄 $age， 可 以 访问 private 属性 

function construct ($name, $sex, $age) ( 
$this-»name-$name; // 传 进来 的 Sname 给 成 员 属性 $this->name 赋 初 值 
$this-»sex-$sex; ，// 传 进来 的 Ssex 给 成 员 属 性 Sthis->sex 赋 初 值 
$Sthis-»age-$age;  ”// 传 进来 的 $age 给 成 员 属 性 Sthis->age 赋 初 值 

} 

function  destruct()( // 这 是 析 构 函数 ， 在 对 象 销毁 前 调用 


echo "再 见 ".$this->name."<br>"; 


} 





) 


YI y 


S uw 


特殊 的 引用 “Sthis” 的 使 用 : 每 个 对 象 都 有 一 个 对 象 的 引用 Stlis 来 代表 它 本 身 ， 完 成 对 对 象 内 部 成 员 


的 调用 。 

7.4.3 ”创建 对 象 , ^N 
1， 创 建 对 象 的 语法 格式 DA 
$objectname=new classname(); X. 


2. (UR SERA boe I x 
$objectname-»pro -newvalue; NS E // 修 改 属 性 
$variablenamé=$objectname->pro! P 4 // 获 取 属 性 
Svariablenarie-Sobjectname-»methodname O; // 执 行 方法 


示例 7-3 ”创建 对 象 





<?php 
// 示 例 7-2 中 的 类 friends 代码 
$pl=new friends(" 张 义 山 "," 男 ", 20) ; 
$p2-new friends (" 李 丽 "," 女 ", 30)，; 
$p3-new friends(" 王 帅 ", " 男 ", 40) ; 
Spl-»sayO; ”// 访 问 $pl1 对 象 中 的 说 话 方法 
$p2-»sayO; ”// 访 问 $p2 对 象 中 的 说 话 方法 
Sp3-»sayO; ”// 访 问 $p3 对 象 中 的 说 话 方法 





我 的 姓名 : 张 义 山 性 别 : 男 年 龄 : 20 
我 的 姓名 : 李 丽 性 别 : 女 年 龄 : 30 
我 的 姓名 : 王 帅 性 别 : 男 年 龄 : 40 
再 见 王 帅 

再 见 李 丽 

再 见 张 义 山 
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7.4.4 ”使 用 对 象 的 属性 和 方法 


l. 使 用 对 象 中 被 封装 的 属性 


一 般 来 说 ， 总 是 把 类 的 属性 定义 为 private 或 protected， 这 更 符合 逻辑 。 但 对 属性 的 读 
取 和 赋值 操作 非常 频繁 , 因此 , PHP 5 中 预定 义 了 _ get0 和 _ set() 方 法 来 获取 和 赋值 其 属性 ， 
以 及 函数 _isset0 和 _ unset() 来 检查 属性 和 删除 属性 的 方法 。 
_ set0 和 _ get0) 不 是 默认 存在 的 ， 需 要 手动 添加 到 类 中 。 可 以 按 下 面 的 方式 来 添加 这 
两 个 方法 。 
//. get () 方 法 用 来 获取 私有 属性 
public void function — get($property name)( 
if(isset(Sthis-»$property name)) return($this-»$property name); 
else return(NULL); 


) 
//__set () 方 法 用 来 设置 私有 属性 CS 
public mixed function _ set($property 1 EN. 


$this-»$property name-$value; 


NS 

(D. get02;k: 用 来 获取 种 有 成 页 md. “参数 传 入 要 获取 的 成 员 属性 的 名 称 ， 返 回 获取 的 属性 值 。 
这 个 方法 不 用 手动 去 调用 ， 而 是 在 直接 多 ole 为 私有 属性 已 经 被 封装 了 ， 是 不 能 
直接 获取 值 的 ， 但 是 如 果 在 类 内 各 上 了 这 个 方法 ， 在 使 用 8E R EIE Qoo mameat, 就 会 自动 
Mo M 将 属性 name 传 给 参数 Sproperty_name， 通 过 这 个 方法 的 内 部 执行 ， 返 回 
传 入 的 私有 属性 值 。 X4N 

© 一 set0 方 法 : 用 AMAA A 性 设置 村 |， TA 个 参数 为 要 设置 值 的 属性 名 ， 第 二 个 参数 是 要 给 
属性 设置 值 ， 函 返回 值 。 这 个 方法 也 不 用 手动 调用 ， 在 直接 设置 私有 属性 值 时 会 自动 调用 ， 私 有 属 
性 已 经 被 封装 上 了 如 果 没 有 _ set() 方 法 ， 就 不 允许 改变 私有 属性 的 值 ， 如 Sthis->name="lili" 会 出 错 ， 但 
是 如 果 在 类 中 定义 了 _ set($property_name,Svalue) 方 法 ， 在 直接 给 私有 属性 赋值 时 ， 就 会 自动 调用 它 ， 把 
属性 如 name 传 给 $property_name， 把 要 赋 的 值 "ili" 传 给 $value， 通 过 这 个 方法 的 执行 ， 达 到 赋值 的 目的 。 


isset0 和 __unset() 与 _get0 和 __setO) 的 原理 差不多 ， 它 们 的 原型 如 下 : 
//_ isset () 方 法 用 来 获取 私有 属性 


public bool isset(string $name )( 
return isset($this-»$name); 














Fi 

//_unset () 方 法 用 来 设置 私有 属性 

public void | unset(string $name )( 
unset ($this-»$name); 

) 


ds. 


O _issetO 用 于 测定 变量 是 否 设 定 可 用 ， 传 入 一 个 变量 作为 参数 ， 如 果 传 入 的 变量 存在 ， 则 返回 
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TRUE; 和 否则， 返回 FALSE. 在 一 个 对 象 外 面 使 用 isset() 去 测定 对 象 里 面 的 成 员 是 否 被 设 定时 ， 如 果 对 象 
的 成 员 是 公有 的 ， 就 可 以 使 用 这 个 函数 来 测定 成 员 属 性 ; 如 果 对 和 象 的 成 员 是 私有 的 ， 这 个 函数 就 不 起 作用 
了 ， 原 因 是 私有 成 员 被 封装 了 ， 在 外 部 不 可 见 .。 在 类 内 加 上 一 个 方法 _isset()， 当 在 类 外 部 使 用 isset() 函 数 
来 测定 对 象 里 面 的 私有 成 员 是 否 被 设 定时 ， 就 会 自动 调用 类 内 的 _isset() 方 法 。 

回 _unset() 的 作用 是 删除 指定 的 变量 且 返 回 TRUE， 参 数 为 要 删除 的 变量 。 使 用 方法 类 似 于 isset). 
unset() 方 法 用 来 在 对 象 的 外 部 删除 对 象 的 私有 成 员 属 性 。_isset() 和 unset() 也 是 自动 触发 的 。 








示例 7-4 ”使 用 方法 _get0、__set0)、__isset0)、__unset0) 获 取 封 装 的 属性 


«?php 
class friends( 

// 下 面 是 朋友 的 成 员 属性 ， 都 是 封装 的 私有 成 员 

private $name; // 朋 友 的 姓名 

private $sex; // 朋 友 的 性 别 

private $age; // 朋 友 的 年 龄 x 

//. get () 方 法 用 来 获取 私有 属性 AK 

public function __get ($property_name){ SN 
echo "在 直接 获取 私有 属性 值 时 ， 自 动 调 lee ) 方 法 <br>"; 
if(isset(Sthis-»$property EN rn(Sthis-»$property name); 
else return (NULL); 


) d WF 

//. set () 方 法 用 米 设置 私有 属性 

public function SS y_name, $value) { 
echo "在 直接 设置 私 LR 中， 自动 调用 cei 
DE $value; 


) 
//. isset( m g A A 
public M isset ($nm) SS 
echó "isset LED. 自动 调用 <br>"; 
éturn isset ($this->$n 
} 
// unset () 方 法 
public function unset ($nm) ( 
echo " 当 在 类 外 部 使 用 unset O 函数 来 删除 私有 成 员 时 自动 调用 的 <br>"; 
unset ($this-»$nm); 
) 
) 
$pl-new friends(); 
// 直 接 为 私有 属性 赋值 的 操作 ， 会 自动 调用 set O 方法 进行 赋值 
$pl->name=" 李 莉莉 "; 
$pl->sex="4r"; 
$pl->age=23; 
// 在 使 用 isset O 函数 测定 私有 成 员 时 ， 自 动 调用 ”isset () 方法 ， 返 回 结果 为 TRUE 
echo var dump(isset($pl-»name))."«br»";  //var dump() 显示 关于 一 个 或 多 个 
表达 式 的 结构 信息 ， 包 括 表 达 式 的 类 型 与 值 
echo" 姓 名 : ".$pl->name."<br>"; 
// 在 使 用 unset () 函数 删除 私有 成 员 时 ， 自 动 调用 _unset () 方法 ， 删 除 name 私有 属性 
369 o 
- 


unset ($pl-»name); 






// 已 经 被 删除 了 ， 所 以 这 行 不 会 有 输出 
echo" 姓 名 : ".$pl-»name."«br»"; 
echo" 性 别 : ".$pl-»sex."«br»"; 
echo" 年 龄 : ".$pl->age."<br>"; 





”在 直接 设 六 私有 属性 值 时， 自动 调用 _set0 方 法 为 私有 属性 赋值 
在 直接 设置 私有 属性 值 时 ， 自 动 调用 _ set() 方 法 为 私有 属性 赋值 
在 直接 设置 私有 属性 值 时 ， 自 动 调用 _set0 方 法 为 私有 属性 赋值 
isset0 函 数 测定 私有 成 员 时 ， 自 动 调用 








bool(true) 
在 直接 获取 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _get0 方 法 

姓名 ， 李 莉莉 
当 在 类 外 部 使 用 unset() 函 数 来 删除 私有 成 员 时 自动 调用 , 
在 直接 获取 私有 属性 值 时 ， 自 动 调用 了 get0 方 法 

isset0) 函 数 测定 私有 成 员 时 ， 自 动 调用 SN 
姓名 Xv 

在 直接 获取 私有 属性 值 时 ， AN 

性 别 : 女 


在 直接 获取 私有 属性 值 时 ， 
年 龄 ，23 UAA 


出 一 个 新 类 。 已 存在 的 用 来 派 
生 新 类 的 类 为 基 类 ， URDU 类 或 超 类 ， 派生 di ,的 新 派生 类 或 子 类 。 即 子 类 可 以 从 
父 类 中 继承 所 有 可 见 的 属性 己方 法 。 PHP 中 用 .extends 关键 他 类 之 间 的 继承 。 
如 果 父 子 两 个 类 都 定 义 了 同名 的 方法 或 属性 ， 则 父 类 的 方法 或 属性 将 会 被 覆盖 ， 即 
Pers 或 $this->methodname0 所 使 用 的 都 是 在 子 类 中 重新 新 定义 的 。 要 在 子 类 中 使 
与 父 类 同名 的 成 员 可 以 使 用 parent::proname() 或 parent::methodname()。 


SÉ un 
不 能 使 用 parent::: construct()f parent::_destruct()， 这 将 导致 递归 调用 ， 最 终 导 致 程序 溢出 错误 。 


如 果 没 有 发 生 覆 盖 ， 使 用 $this->proname() 或 $this->methodname() 访 问 到 的 就 是 父 类 中 
定义 的 方法 或 属性 。 在 子 类 中 ， 可 以 添加 新 的 属性 或 方法 ， 使 得 类 的 功能 更 具有 针对 性 。 

通过 类 的 继承 ， 可 以 快速 实现 程序 的 功能 ， 在 很 大 程度 上 提高 了 代码 的 复 用 程度 。 但 
从 程序 性 能 上 来 说 ， 继 承 使 程序 变 慢 了 ， 特 别 是 经 过 多 层 的 继承 之 后 ， 类 与 类 之 间 的 关系 
将 会 变 得 复杂 ， 这 将 需要 更 多 的 时 间 来 编译 。 因 此 ， 建 议 自 定义 的 类 控制 在 3 层 以 内 的 继 
承 。 少 用 类 继承 多 用 类 组 合 是 面向 对 象 设计 的 一 个 原则 。 

在 PHP 5 中 ， 不 允许 类 拥有 多 个 父 类 ， 子 类 只 能 从 一 个 父 类 继承 。 













































































示例 7-5 “我 的 朋友 ”类 派生 “同学 ” 子 类 
<?php 
class friends{ 
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function say()( 
echo "我 的 名 字 叫 ; ".$this->name." 人 性别: ".S$this-»sex." 人 年龄: 
".Sthis->age." dE".Sthis-»school." EAM.«br»"; 
à 
) 

$pl-new friends (" 张 义 山 "，" 男 "，40) 7 

$p2-new student (" 王 帅 "，" 男 "，20, "ECNU") ; 

Spl-»sayO;  // 访 问 SP1 对 象 中 的 说 话 方法 

$p2-»sayQ;  //Uii]Sp2 对 象 中 的 说 话 方法 








我 的 姓名 : 张 义 山 性 别 : 男 年 龄 : 40 
我 的 名 字 叫 : 王 帅 性 别 : B 年 龄 : 20 在 ECNU 上 学 


再 见 王 帅 h 

再 见 张 义 山 NY 

3. 类 抽象 \ 

在 类 内 定义 的 没有 方法 体 的 方法 就 是 ee 无 论 
抽象 方法 还 是 抽象 类 ， 最 前 面 都 要 使 用 vi 


A 
abstract class Demo{ N 


public $test; - 
abstract ad NN AN 
function fun3(){ — 7 x 
E 4 XML 
"X 
d 


AT E S 


抽象 类 无 法 按 用 new 创建 对 象 ， 它 必须 被 子 类 继承 ， 并 且 在 子 类 中 对 抽象 方法 加 以 
定义 。 定 义 抽象 英 就 相当 于 定义 了 一 种 规范 ， 这 种 规范 要 求 子 类 去 遵守 ， 子 类 继承 抽象 类 
之 后 ， 把 抽象 类 里 面 的 抽象 方法 按照 子 类 的 需要 实现 。 子 类 必须 把 父 类 中 的 抽象 方法 全 部 
实现 ， 否 则 子 类 中 还 存在 抽象 方法 ， 那 么 子 类 还 是 抽象 类 。 

74.5 对 象 的 操作 

.序列 化 

serialize0 返 回 一 个 字符 串 ， 包 含 可 以 储存 于 PHP 的 任何 值 的 字 节 流标 识 。unserialize0 
可 以 用 此 字符 串 来 重建 原始 的 变量 值 。 用 序列 化 来 保存 对 象 中 的 所 有 变量 。 对 象 中 的 函数 
不 会 被 保存 ， 只 保存 类 的 名 称 。 

使 用 serialize() 序 列 化 类 A 的 对 象 Sa， 将 得 到 一 个 指向 类 A 的 字符 串 并 包含 所 有 Sa 中 
变量 的 值 。 使 用 unserialize() 将 其 解 序列 化 ， 重 建 类 A 的 对 象 Sb， 如 示例 7-6 所 示 。 































































































示例 7-6 序列 化 
«?php 
class A ( 











public $one-1; 
function show one()( 
echo $this-»one; 

) 
) 
// 定 义 类 A 并 创建 对 象 Sa 
$a-new A; 
$s-serialize($a); 
echo $s; // 可 见 序列 化 后 的 值 
$b-unserialize($s); // 创 建 类 A 的 对 象 Sb 
$b-»show one(); // 可 以 使 用 类 A 的 方法 


?> 





0:1:"A":1:(s:3:"0ne";i1:1;])1 » / 

如 果 在 用 会 话 并 使 用 了 session_register() 来 注册 对 象 ， 这 些 对 象 会 在 每 个 PHP 页 面 结束 
时 被 自动 序列 化 ， 并 在 接 下 来 的 每 个 页 面 中 自动 解 序列 化 。 也 就 是 说 ， 这 些 对 象 一 旦 成 为 
会 话 的 一 部 分 ， 就 能 在 任何 页 面 中 出 现 。 

因此 ， 如 果 在 以 上 的 例 : ilias 通过 运行 session | register("a a") 成 为 会 话 的 一 部 分 ， 则 应 

该 在 所 有 的 页 面 中 包含 类 A 的 定 
2. 对象 的 比较 
当 使 用 比较 操作 符 (一 ) 时 3 ARD -种 很 简单 TS 如 两 个 对 象 有 相同 的 属性 和 

值 ， 届 于 同一 个 类 且 被 定义 在 相同 的 命名 空间 中 ， 则 两 个 对 象 相等 。 

另外 , SEHER, 当 且 仅 当 两 个 对 象 指 向 相同 类 (在 某 
的 同一 个 对 象 时 才 相 等 ， 如 示例 7-7 Brass 
























特定 的 命名 空间 中 ) 


示例 7-7 PHP5 中 对 象 比 较 与 赋值 
<?php 
function bool2str ($bool1){ 
if($bool---false) return 'FALSE'; 





else return 'TRUE'; 


) 

function compareObjects (&$01, &$02) ( 

echo 'ol--02:'.bool2str($01--$02) ."«br/»"; // 对 象 比较 
echo 'ol---02:'.bool2str($01---$02)."«br/»";  // 对 象 全 等 比较 


) 
class Flag( 
public $flag; 
function Flag(S$flag-true) (Sthis-»flag-$flag;) 
) 
$o-new Flag(); 
$p-new Flag(); 


$q-$0; // 对 象 赋值 


^C) 
($ 575 “网 上 购书 与 pHp 面向 对 象 技术 
© 一 







echo "Two instances of the same class.«br/»"; 
compareObjects ($0, $p); 

echo "Two references to the same instance.<br/>"; 
compareObjects ($0, $q); 


Two instances of the same class. 
==02: TRUE 

01---02:FALSE 

Two references to the same instance. 

01--02:TRUE 

01---02: TRUE 


CET Cx 
在 PHP 4 中 ,对象 比较 的 规则 十 分 简单 :如果 两 个 对 象 的 类 相同 自 它 们 有 相同 的 属性 和 值 ， 则 这 两 
EVE, A RUMOR T RAE CSS en Rl 
3， 对 象 的 赋值 与 复制 


对 象 的 赋值 运算 都 是 地 址 赋值 ， ETE -个 对 象 , 如 示例 7-7 中 的 $q=$o; 语句 。 

相当 于 给 对 象 $o 又 起 了 个 别名 $q， 修改 其 中 的 一 个 就 会 引起 另 一 个 的 改变 。 

使 用 关键 字 clone 能 复制 出 :相同 的 对 象 ， 相 "oido -个 备份 ， 新 对 象 与 原 
对 象 之 间 是 独立 的 ， 修改 其 中 的 < -个 不 会 引起 另 :个 的 改变 ， 如 示例 7-8 所 示 。 


«?phj b vi " 
jd AS DA 


class : EET 


enti function — construct()( 
global $value; 
$valuett; 
h 
public function clone (){ 
global $value; 
$value=3; 
) 
) 
echo"1 .类 外 : ".$value."«br/»"; 
$objectl=new cloneclass(); 
echo"2 .创建 对 象 : " .$value."<br/>"; 
$object2-clone $objectl; 
echo"3 .复制 对 象 : ".$value."«br/»"; 


ES 





2 .创建 对 象 : 1 
3 .复制 对 象 : 3 


ss 





本 节 案例 实现 的 功能 较 复杂 ， 采用 了 面向 对 象 的 技术 ， 从 中 可 以 体会 PHP 面向 对 象 技 
术 在 复杂 系统 中 的 优势 。 


tà $4652 


O) 本 节 案例 中 如 何 利用 面向 对 象 技术 操作 数据 库 ? UN Dispo 
D 本 节 案例 中 图 书信 息 是 数据 的 主体 ， AIME “图 书 ” 类 ? 
Q) 定义 “图书” 类。 


€ nas > A 
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项 目 目标 : JP 
() REEDA Ká 
O) 省 ROPA 能 
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网 站 优化 与 PHP 的 高 级 功能 


通过 本 章 的 学 习 ， 能 够 使 读者 : 

(1) 了 解 PHP 对 用 户 管理 的 策略 。 

(2) 理解 PHP 的 常用 GD 库 、 正 则 表达 式 等 概念 = 
(3) 掌握 在 PHP 中 文件 上 传 的 方法 。 

(4) 理解 PHP 支持 的 邮件 系统 ， 


本 章 为 读者 准备 了 以 下 学 TRR: OX 

(1) 示范 案例 ;> 展示 了 一 组 “网 站 优化 ” 如 注册 中 验证 码 、 图 像 文 件 的 上 传 、 电 子 邮 
箱 和 正则 表达 式 的 应 用 等 的 设计 与 实现 过 程 ;< 对 应 本 章 的 8.1 一 8.4 节 。 案 例 代码 存放 在 文 
件 夹 “ 教 学 资源 \wiya\register” 和 “教学 资源 \wuya\webshop” 中 。 

(2) 技术 要 点 : 描述 “PHP 的 GD 图 像 库 、 邮 件 系 统 和 正则 表达 式 ” 的 技术 要 点 ， 对 
应 本 章 的 8.1 一 8.4 节 的 相关 部 分 。 其 中 的 示例 给 出 了 相关 技术 的 说 明 实 例 ， 代 码 存放 在 文 
件 夹 “ 教 学 资源 \extend\ch8\” 中 。 

(3) 实践 项 目 : 代码 存放 在 文件 夹 “ 教 学 资源 \exercise\ch8\” 中 。 


在 学 习 过 程 中 ， 建 议 读者 按 以 下 顺序 学 习 : 

(1) 解读 示范 案例 的 分 析 和 设计 。 

(2) 模仿 练习 : 选择 PHP 集成 开发 工具 ， 如 Dreamweaver, ZH: BUE WEGE HL SEA). 

(3) 扩展 练习 : 按 实践 项 目的 要 求 ， 先 明确 项 目 目标 ， 再 在 PHP 集成 开发 环境 中 实现 
项 目 代码 ， 接 着 对 代码 中 的 PHP 语言 要 素 进 行 分 析 ， 提 升 理解 和 应 用 能 力 。 

学 习 过 程 中 ,提倡 结对 或 3 人 组 成 学 习 小 组 ， 一 起 探讨 和 研究 会 员 注册 和 管理 的 设计 ， 
但 对 PHP 高 级 功能 的 学 习 和 具体 项 目的 实现 还 是 鼓励 能 独立 完成 。 
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章 案例 介绍 如 何 使 用 PHP 的 高 级 功能 ， 如 正则 表达 式 与 电子 邮件 系统 、GD 
户 安 全 策略 、 文 件 上 传 等 。 


S 预备 知识 
8.1 用 户 注册 安全 管理 


8.1.1 用户 注 册 安 全 管理 的 策略 

















甚至 会 面临 丢失 账号 和 密码 的 危险 。 因 此 ， 动 态 网 站 中 
外 ， 网 络 上 的 自动 注册 机 、 抢 号 机 等 表单 提交 操作 会 br) 














库 与 用 


当 用 户 注册 或 登录 时 ， 提 交 输 入 的 信息 可 能 会 LEN 
EMI HERR AL E 


Heip aa anea e = o 多 ， 即 程序 可 以 轻易 地 获取 有 价 
信息 











值 的 文字 信息 ， Ne 
这 样 ， 在 用 户 提交 表单 前 ， 通 过 ide 

图 中 包含 几 个 字符 ， 计 算 机 很 难 识别 

提交 行为 才 认为 是 有 效 的 提交 否则 ; stem. ER 
改进 的 注册 和 登录 页面 如 图 8 上 所 示 。 





的 方式 能 有 效 地 加 强 安全 性 管理 。 


Ee rr > EE 





S EIE 465 TELEL 


J TA 
NS ee nenen 
x 请 输入 会 员 号 
请 往生 B i 
wumseneES[  ] NTIZI 
(EK) CERERER ) 








lopyright$0010 wuyabook@con 无 涯 网 上 书店 版 权 所 有 
PARANEE ESERE USERS 编号 ， 沪 IcPiExxxzzz 呈 
建议 济 拉 器 分 状 率 :1024X 068 





图 8.1 改进 的 注册 和 登录 页 面 


(全 pup 


8.1.2 ”优化 用 户 注册 页 面 


l. 验证 码 的 生成 


代码 文件 ，yzm.php 


即 在 位 





具 别 ， 只 有 将 位 图 中 的 代码 正确 输入 文本 框 的 
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(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 
ji“ 代码 ”标签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 











<?php 
@session start (); 
define("CHARS lLENGTH",4); VU ih n CHARS lLENGTH 
function getVerify()| // 生 成 验证 码 


$strings-array('0','1','2', '3', 4! , 5! , '6' , 7! , !8', !9', 'a' , 'b', 'c', 'd', 
'et, !£','g!,'h','i','j','k 





,'m','n', 'o','p','q','r','s','t','u','v', 'w', 


xp y 
SchrNum-""; // 验 证 码 字 符 
$count-count ($strings); // 统 计 预 设 字符 的 个 数 
for ($i=1; $i<=CHARS 1LENGTH; $i++) 
$chrNum.=$strings[rand(0,$count-1)]; // 生 成 个 随机 字符 
return $chrNum; 
} 
function GetImage ($strNum) { 生成 验证 码 图 像 





$fontSize-15; $width-70; S$height-24; $lineNum-5; $pointNum-32; 
Sim-imagecreate ($width*5,$heightf5); 
$backgrountColor-imagecolorallocate ($im,255,239,206); 
$frameColor-imagecolorallocate($im,155,155,155); 
$stringColor-imagecolorallocate ($im,30,30,30); 
$font-realpath("FONT PATH/arial.ttf"); 
for ($i=0; $i<CHARS TLENGTH; $i++) { H8 4 位 
$charY- (Sheight-*Sheight/2)/2*rand(-1;1); 
$charX-$i*1548; 
$text color-imagecolorallocate(Sim,mt rand(50,200),mt rand(50,128), 
mt rand(50,200)); 
Sangle-rand(-30,30); 
imagettftext ($im, $fontSize, $angle, $charX, $charY, $text color,$font, 
SstrNum[$i]); 
) 
for ($i-0;$i«-SlineNum; $i++) { // 在 创建 的 图 像 区 域内 绘制 杂 线 
$linecolor=imagecolorallocate ($im,mt rand(0,255),mt rand(0,255), 
mt rand(0,255)); 
$lineX=mt rand(1,S$width-1); 
$lineY-mt rand(1,$height-1); 
imageline ($im, $lineX, $lineY, $lineX+mt rand(0,4)-2,$1ineY4mt rand 
(0,4)-2, $1inecolor); 
) 
for ($i=0; $i<=$pointNum; $i++) { // 在 创建 的 图 像 区 域内 绘制 杂 点 
$pointcolor=imagecolorallocate ($im,mt rand(0,255),mt rand(0,255), 
mt rand(0,255)); 





字符 图 形 化 处 理 


imagesetpixel(Sim,mt rand(1,Swidth-1)， mt rand(1,$height-1), 
$pointcolor); 


) 
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imagerectangle ($im,0,0,$width-1,$height-1,$framecolor); // 在 $im 创建 的 图 
像 中 绘制 长 方形 

ob_clean () ; // 清 除 输 出 缓冲 
header('Content-type:image/png'); // 设 置 向 浏览 器 输出 文件 的 类 型 
imagepng($im); // 输 出 创建 的 图 像 $im 
imagedestroy($im); ”// 销 毁 创建 的 图 像 $im 
exit; 

$ 

$chars= getVerify(); 

$_SESSION['chars']=$chars; // 存 储 当前 的 验证 码 ， 用 于 对 用 户 输入 时 的 验证 

imagejpeg(GetImage($chars));  // 输 出 生成 的 验证 码 图 像 

?> 





(3) 把 文档 以 yzm.php 为 文件 名 保存 在 站 点 的 register 文件 夹 下 。 
(4) 在 register 文件 夹 下 建立 文件 夹 FONT_PATH， 并 把 arialittf 复制 于 此 。 


人 
MORRA 


这 段 代码 生成 4 人 







正 码 字 符 ， 并 以 图 像 方式 输出 .其 中 使 用 到 GD 函数 库 ， 详 解 见 8.1.3 节 
第 4~ 11 行 : 按 预 设 字符 随机 生成 4 位 验证 码 字 符 ， 
第 12~41 fr: 对 4 位 验证 码 字符 生成 图 形 并 处 理 ， 其 中 : 
第 13 行 : 设置 字符 的 字号 、 图 片区 的 大 小 、 杂 线 和 杂 点 的 数量 
第 14~ 17 行 : 使 用 GD 函数 库 的 函数 imagecreate() 创 建 图 像 v Vimagecolorallocate() 设 置 图 像 的 背景 
色 、 外 框 线 和 字符 的 颜色 ，realpath() 设 置 字体 5 
第 19~ 25 行 : 对 4 位 验证 码 字符 图 形 化 处 理 
第 26~31 行 : 使 用 函数 imageline() 在 创建 的 图 像 区 域内 绘制 杂 线 
第 32-35 行 : 使用 函数 imagesetpixel0 在 创建 的 图 你 区 域内 绘制 杂 点 


2. 相关 文件 的 修改 








代码 文件 :regindex.php、login.php 





(1) 在 Dreamweaver 中 ， 打 开 站 点 的 register 目录 下 的 文件 regindex.php。 
(2) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 添 加 如 下 代码 。 


«script language-"JavaScript"» 
function jcud()( 
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(3) 保存 文件 。 
代码 文件 : login.php 


(4) 在 Dreamweaver 中 ， 打 开 站 点 的 register 目录 下 的 文件 login.php。 
(5) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 添 加 如 下 代码 。 





获取 表单 变量 的 值 





(6) 保存 文件 。 


mao 


8.1.3 PHP 的 GD 函数 库 


PHP 不 仅 限于 只 产生 HTML 的 输出 ， 还 可 以 创建 及 操作 多 种 不 同 图 像 格式 的 图 像 文 
件 ， 包 括 gif. png. jpg. wbmp 和 xpm。 更 方便 的 是 ,PHP 可 以 直接 将 图 像 流 输出 到 浏览 
器 。PHP 操作 图 像 是 通过 其 图 像 函 数 库 实现 的 % 最 有 名 的 是 GD( 图 形 设备 ) 库 。GD 库 是 第 

: 方 的 软件 包 ， 一直 与 PHP 有 良好 的 结合 。 

要 处 理 图 像 ; 和 需要 在 编译 PHP 时 加 上 图 像 函数 的 GD 库 。GD HERI PHP 还 可 能 需要 其 
他 的 库 ， 视 需要 支持 哪些 图 像 格 式 而 定 。 

1， 启 用 PHP 的 GD 函数 库 

由 PHP 中 GD 库 默 认 是 关闭 的 ， 因 此 使 用 GD 库 前 首先 要 启用 该 函数 库 。 

(1) 打开 配置 文件 php.ini， 将 extension-php. gd2.dll 前 面 的 分 号 删除 。 

(2) 把 PHP 安装 目录 中 的 \ext\php_gd2.dll 复制 到 C:\windows\system32 中 。 

(3) 同时 把 \extphp_gd2.dll 复制 到 apache\bin 目录 中 。 

(4) 重新 启动 Apache. 

验证 GD 库 是 否 启动 ， 可 以 用 函数 gd_info0) 获 取 有 关 人 信息。 代码 如 下 。 











示例 8-1 test_GD.php /存放 在 站 点 根 目录 下 的 extends/ex8 
«?php 
$info-gd info(); 


foreach ($info as $id=>$value) 
echo $id.":".$value."Xbr/»"; 
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GD Version:bundled (2.1.0 compatible) 
FreeType Support:1 

FreeType Linkage:with freetype 

TlLib Support: 

GIF Read Support:1 

GIF Create Support:1 

JPEG Support:1 

PNG Support:l 

WBMP Support:1 

XPM Support:1 

XBM Support:1 

WebP Support:1 

JIS-mapped Japanese Font Support: X 入 


函数 原型 array gd info ( void ) // 取 得 当前 安装 的 \GB 库 的 信息 
2， 获 取 支 持 的 图 像 格式 信息 


目前 有 上 百 种 数字 图 像 格式 , GD 库 在 不 断 补充 更 新 中 , 可 以 通过 获取 最 新 的 GD 库 来 





扩展 PHP 网 像 处 理 能 力 ， 当 前 默认 的 GD 库 已 经 可 以 满足 我 们 的 需要 了 。 
使 用 函数 imagetypes0) 能 以 比特 字段 方式 返回 与 当前 PHP 版 本 关联 的 GD 库 所 支持 的 
图 像 格式 。 将 返回 以 下 结果 : IMG GIF |IMG_JPG | IMG PNG | IMG_WBMP。 








? A 
D LO T a $5 M | GIF) NE E 
echo ZA S AM is enabled" r 


?> 4122 
GIF -— is enabled 


函数 原型 ， int imagetypes ( void ) // 返 回 当前 PHP 版 本 所 支持 的 图 像 类 型 
IMG GIF 是 预定 义 常 量 ， 其 他 常用 的 图 像 格 式 预定 义 常 量 如 表 8.1 所 示 。 
表 8.1 图 像 类 型 常量 与 对 应 的 值 
































常 量 * 5 
IMAGETYPE GIF IMG GIF 
IMAGETYPE JPEG IMG JPG | IMG. JPEG 
IMAGETYPE PNG IMG PNG 
IMAGETYPE SWF IMG. WBMP 
IMAGETYPE PSD IMG XPM 
IMAGETYPE BMP 
IMAGETYPE TIFF II (intel byte order) 
IMAGETYPE TIFF. MM (motorola byte order) 
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(1) 左边 是 被 image_type_to_mime_type() 和 image type to extension() 函数 所 用 的 图 像 类 


型 常量 。 右边 是 被 imagetypes() 函数 作为 返回 值 使 用 的 常量 。 
(2) 由 于 这 些 常 量 是 由 扩展 模块 定义 的 ， 因 此 只 有 在 该 扩展 模块 被 编译 到 PHP 中 ,或 者 在 


运行 时 被 动态 加 载 后 ， 这 些 常量 才 有 效 。 


3. PHP 的 GD 函数 库 


GD 函数 库 包 含 了 10 多 个 函数 ， 用 于 对 图 像 的 处 理 ， 根 据 功 能 可 以 分 为 以 下 几 类 ; 


(1) 有 关 图 像 文件 属性 的 函数 如 表 8.2 所 示 。 








X82 图 像 文 件 属性 的 函数 
函数 说 m" 
array getimagesize ( string Sfilename [, array &Simageinfo ] ) 取得 图 像 大 小 


array getimagesizefromstring ( string $imagedata [, array &Simageinfo ] ) 
string image type to extension ( int Simagetype [, bool Sinclude dot = TRUE ] ) 


string image type to mime type ( int Simagetype ) 


(2) 相关 图 像 输 出 格式 的 函数 如 表 .8.3\ 所 示 。 


从 字符 串 中 获取 图 像 尺寸 信息 
取得 图 像 类 型 的 文件 后 级 
取得 getimagesizeexif read data 


exif thumbnailexif imagetype 所 返 
回 的 图 像 类 型 的 MIME 类 型 





表 8.3、 图 像 输出 格式 的 函数 


函数 
int image2wbmp ( resource $image [, string $filename [, int 
Sthreshold ]]) 
bool imagegif ( resource Simage [, string Sfilename ]) 
bool imagepng ( resource $image [, string $filename ]) 
bool imagejpeg ( resource $image [, string $filename [, 
int Squality ]] ) 
bool imagewbmp ( resource $image [, string Sfilename[, 
int Sforeground ]] ) 


说 有 明 
以 WBMP 格式 将 图 像 输出 到 浏览 器 或 文件 


以 GIF 格式 将 图 像 输出 
以 PNG 格式 将 图 像 输出 到 浏览 器 或 文件 


以 JPEG 格式 将 图 像 输出 到 浏览 器 或 文件 


以 WBMP 格式 将 图 像 输出 到 浏览 器 或 文件 





bool imagewebp ( resource Simage , string $filename ) 


各 WebP 格式 的 图 像 输出 到 浏览 器 或 文件 





bool imagexbm ( resource $image , string $filename [. 
int Sforeground ] ) 





将 XBM 图 像 输出 到 浏览 器 或 文件 





bool jpeg2wbmp ( string $jpegname , string $wbmpname , 
int Sdest. height , int Sdest. width , int Sthreshold ) 


*t JPEG 图 像 文件 转换 为 WBMP 图 像 文件 





bool png2wbmp ( string Spngname , string Swbmpname , 
int Sdest. height , int $dest. width , int Sthreshold ) 





将 PNG 图 像 文 件 转换 为 WBMP 图 像 文件 





bool imagegd2 ( resource $image [, string $filename [, 
Int $chunk size [, int $type = IMG. GD2 RAW ]]]) 











输出 GD2 图 像 











int imagegd(resource image [, string filename]) 


(3) 相关 新 建 图 像 的 函数 如 表 8.4 所 示 。 


























4 GD 





图 像 输出 到 浏览 器 或 文件 
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表 8.4 新 建 图 像 的 函数 





























函数 gio" 
resource imagecreate ( int $x. size , int Sy. size ) 新 建 一 个 基于 调 色 板 的 图 像 
resource imagecreatefromgd2 ( string Sfilename ) 从 GD2 文件 或 URL 新 建 图 像 





从 GD 文件 或 URL 新 建 图 像 


resource imagecreatefromgd ( string Sfilename ) 





resource imagecreatefromgd2part ( string $filename , 


从 给 定 的 GD2 文件 或 URL 中 的 部 分 新 建 图 像 
int SsrcX , int $srcY , int $width , int $height ) aE R 的 部 分 新 建 图 像 





从 GIF 文件 或 URL 新 建 图 像 


resource imagecreatefromgif ( string Sfilename ) 





resource imagecreatefromjpeg ( string Sfilename ) 从 JPEG 文件 或 URL 新 建 图 像 





M PNG 文件 或 URL 新 建 图 像 


Tesource imagecreatefrompng ( string $filename ) 





从 字符 串 中 的 图 像 流 新 建 图 像 


resource imagecreatefromstring ( string Simage ) 





从 WBMP 文件 或 .URL 新 建 图 像 
从 WebP 文件 或 URL 新 建 图 像 
A XBM 文件 或 URL 新 建 图 像 
从 XPM 文件 或 URL 新 建 图 像 
新 建 一 个 真 彩色 图 像 

销毁 图 像 


resource imagecreatefromwbmp ( string Sfilename ) 
resource imagecreatefromwebp ( string $filename ) 


resource imagecreatefromxbm ( string Sfilename ) 





resource imagecreatefromxpm ( string Sfilename ) 


resource imagecreatetruecolor ( int Swidth , int Sheight ) 





int imagedestroy(resource image) 
(4) 相关 绘制 图 形 的 函数 如 表 .8:5 所 示 。 
表 8.5 绘制 图 形 的 函数 


函数 说 m" 
nt $e , int $color) LUGENN 
int $color ) 画 一 条 直线 





bool imagearc(resource $image , int Scx , int Scy , int $w , int $h yintSs 





bool imageline ( resource Simage , int $x1 , int $y1 , int $x2 , int Sy: 


























bool imagerectangle ( resource $image , int x1 , int $y1 , int $x2 $y2 , int Scol ) 时 | 

bool imagedashedline(resource $image , int $x1 , int $y1 , int $x2 , int $y2 , int $color) inj — 

bool imageellipse(resource Simage , int Scx , int Scy , int Swidth , int Sheight , int Scolor) 画 一 个 椭圆 

bool imagesetbrush ( resource Simage , resource Sbrush ) 面 一 个 矩形 

bool imagepolygon ( resource Simage , array $points , int Snum_points , int Scolor ) 画 一 个 多 边 形 

bool imagesetpixel ( resource Simage , int $x , int $y , int Scolor ) 画 一 个 单一 像素 
bool imagesetstyle ( resource Simage , array Sstyle ) 设 定 画 线 的 风格 
bool imagesetthickness ( resource Simage , int Sthickness ) 设 定 画 线 的 宽度 
bool imagesettile ( resource $image , resource Stile ) 设 定 用 于 填充 的 贴图 
bool imagefill(resource $image , int $x , int $y , int Scolor) 区 域 填充 





bool imagefilledarc ( resource $image , int Scx , int Scy , int Swidth, int $height , 


画 一 个 填充 椭圆 弧 
int $start int $end , intScolor , int Sstyle ) E 








p imagefilledellipse ( resource $image , int Scx , int Scy , int Swidth , int Sheight , 画 一 个 填充 椭圆 
int Scolor ) 
bool imagefilledpolygon ( resource $image , array Spoints , int $num points , int Scolor ) 画 一 个 填充 多 边 形 








bool imagefilledrectangle ( resource $image , int $x1 , int $y1 „int $x2 , int Sy2 , int Scolor ) 画 一 个 填充 矩形 
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区 域 填充 到 指定 颜 
bool imagefilltoborder ( resource $image , int $x , int $y , int $border , int Scolor ) Ein I SERA 
设 定 画 线 用 的 画笔 
bool imagefilltoborder ( resource Simage , int $x , int Sy , int $border , int Scolor ) "o RH 
bool imagesetinterpolation ( resource $image [, int $method = IMG. BILINEAR . 设置 插值 方法 
FIXED ]) 
(5) 相关 图 像 处 理 的 函数 如 表 8.6 所 示 。 
表 8.6 图 像 处 理 的 函数 
函数 LEE: 
bool imagealphablending ( resource $image , bool $blendmode ) 设 定 图 像 的 混 色 模式 
int imagecolorallocate ( resource $image , int Sred , int Sgreen , int $blue ) 为 图 像 分 配 颜 色 


int imagecolorallocatealpha ( resource $image , int $red , int Sgreen , 
int Sblue , int Salpha ) 

int imagecolorat ( resource $image , int $x , int $y ) 

int imagecolorclosest ( resource $image , int Sred , int Sgreen , int Sblue ) 
int imagecolorclosestalpha ( resource $image , int $red , int Sgreen , 
int $blue ,int Salpha ) 

int imagecolorclosesthwb ( resource Simage , int Sred , int Sgreen , 
int Sblue ) 

bool imagecolordeallocate ( resource $image , int Scolor ) 

int imagecolorexact ( resource $image , int Sred , int Sgreen , int Sblue ) 
int imagecolorexactalpha ( resource $image , int Sred , int Sgreen , 


int Sblue , int Salpha ) 


bool imagecolormatch ( resource Simagel , resource Simage2 ) 


int imagecolorresolve ( resource Simage , int Sred , int Sgreen , int Sblue ) 


为 图 像 分 配 颜 色 + alpha 


颜色 索引 值 
颜色 最 接近 的 颜色 


取得 某 信 
区 得 
索引 值 

取得 与 指定 颜色 + alpha 最 接近 的 
颜色 
取得 与 给 定 颜色 最 接近 色 度 的 黑 
白色 的 

取消 先前 分 配 的 颜色 

取得 指定 颜色 的 索引 值 










取得 指定 的 颜色 + alpha 的 索引 值 


使 图 像 中 调 色 板 版 本 的 颜色 与 真 
彩色 版 本 更 能 瞻 配 

得 指定 颜色 的 索引 值 或 有 可 能 
得 到 的 最 接近 的 替代 值 





int imagecolorresolvealpha ( resource Simage , int Sred , int $green , 
int Sblue , int Salpha ) 


取得 指定 颜色 + alpha 的 索引 值 或 
有 可 能 得 到 的 最 接近 的 替代 值 





void imagecolorset ( resource $image , int Sindex , int Sred , int $green , 
int $blue ) 





给 指定 调 色 板 索 引 设 定 颜色 





array imagecolorsforindex ( resource $image , int Sindex ) 


芭 得 某 索 引 的 颜色 





int imagecolorstotal ( resource Simage ) 





了 得 图 像 的 调 色 板 中 颜色 的 数目 








int imagecolortransparent ( resource $image [. int Scolor ] ) 





将 某 个 颜色 定义 为 透明 色 





bool imagecopy ( resource $dst_im , resource $src_im , int Sdst x , 
int $dst. y , int $src x , int $src. y , int$src w , int Ssrc h ) 














复制 图 像 的 一 部 分 





bool imagecopymerge ( resource $dst_im , resource Ssrc_im , int $dst_x , 
int Sdst, y , int Ssrc. x , int $src. y , intSsrc. w , int Ssrc. h , int Spct ) 





复制 并 合并 图 像 的 一 部 分 
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bool imagecopymergegray ( resource $dst_im , resource $src_im , 
int $dst x , int $dst. y , int $src x , int $src. y iint $src w , int Ssrc h, 
int $pct ) 


用 灰 度 复制 并 合并 图 像 的 一 部 分 





bool imagecopyresampled ( resource $dst_image , resource Ssrc_image , 
int Sdst. x , int $dst_y , int Ssrc_x , int$src. y , int $dst w , int Sdst h, 
int Ssrc w , int $src h ) 


重 采 样 复制 部 分 图 像 并 调整 大 小 





bool imagecopyresized ( resource $dst_image , resource $src image , 
int $dst. x , int $dst_y , int $src. x , int$src. y , int $dst w , int Sdst h, 
int Ssrc w , int $src h ) 


复制 部 分 图 像 并 调整 大 小 





bool imagegammacorrect ( resource $image , float Sinputgamma , 
float Soutputgamma ) 


对 GD 图 像 应 用 gamma 修正 





resource imagegrabscreen ( void ) 

resource imagegrabwindow ( int Swindow, handle [, int Sclient area 
-0]) 

int imageinterlace ( resource Simage [, int Sinterlace ] ) 

bool imageistruecolor ( resource Simage ) 


bool imagelayereffect ( resource $image , int Seffect ) 
void imagepalettecopy ( resource Sdestination , resource $source ) 


bool imagepalettetotruecolor ( resource Ssrc ) 


resource imagerotate ( resource Simage , float Sangle , int $bgd color 
[, int Signore transparent = 0 ] ) 


bool imagesavealpha ( resource Simage , bool Ssaveflag ) 


resource imagescale ( resource $image , int Snew width [, int Snew_ 
height = -1 [, int $mode = IMG BILINEAR FIXED ]] ) 


resource imagecrop ( resource $image , array Srect ) 


捕捉 这 个 屏幕 

捕 提 一 个 窗口 

激活 或 禁止 隔行 扫描 

检查 图 像 是 否 为 真 彩色 图 像 

给 指定 的 分 层 效果 设置 alpha 混 
合 标志 

将 调 色 板 从 一 幅 图 像 复 制 到 另 一 
幅 图 像 

将 基于 图 像 的 调 色 板 转换 为 真 彩 
图 像 

用 给 定 角度 旋转 图 像 

为 保存 PNG 图 像 时 保存 完整 的 
alpha 通道 信息 设置 标记 (与 单 
透明 色相 反 ) 


使 用 给 定 的 宽度 和 高 度 缩放 图 像 














用 给 定 的 坐标 (x,y)、 宽 度 和 高 度 
剪 切 图 像 





resource imagecropauto ( resource Simage [, int $mode = -1 [, float 
Sthreshold = .5 [, int $color = -1 ]]] ) 


用 可 用 的 模式 之 一 自动 剪 切 图 像 





bool imagefilter ( resource Ssrc im , int Sfiltertype [, int Sargl [, int 
Sarg2 [, int Sarg3 ]]] ) 


对 图 像 使 用 过 滤器 





bool imageflip ( resource Simage , int $mode ) 


使 用 一 个 给 定 的 模式 翻转 图 像 





int imagesx ( resource Simage ) 





取得 图 像 宽 度 








int imagesy ( resource Simage ) 








取得 图 像 高 度 








bool imagetruecolortopalette(resource Simage , bool Sdither , int 
$ncolors ) 


将 真 彩色 图 像 转 换 为 调 色 板 图 像 





mixed iptcembed ( string Siptcdata , string Sjpeg_file_name [, int 
$spool ] ) 


Kr] IPTC 数据 嵌入 一 幅 
JPEG 图 像 中 








array iptcparse ( string $iptcblock ) 





将 二 进 制 IPTC 块 解析 为 单个 标记 


第 8 章 


(6) 相关 字符 图 像 的 函数 如 表 8.7 所 示 。 
X87 字符 图 像 的 函数 
A —* 


网 站 优化 与 PHP 的 高 级 功能 


LR 





bool imagechar(resource $image , int Sfont , int $x , int Sy , string $c , int color) 





bool imagecharup(resource $image , int Sfont , int $x , int $y , string Sc , int Scolor) 


KENE 
TESEN 





bool imagestring(resource $image , int $font , int $x , int Sy , string $s , int Scol) 








bool imagestringup(resource $image , int Sfont , int $x , int Sy , string $s , int Scol) 


水 平地 画 一 行 
f 








bool imageantialias ( resource $image , bool Senabled ) 


是 否 使 用 抗 锯齿 (antia 
lias) 功能 





int imagefontheight ( int $font ) 


体高 度 








int imagefontwidth ( int Sfont ) 


取得 字体 宽度 





array imageftbbox ( float $size , float Sangle , string $fontfile , string $text 
[, array Sextrainfo ] ) 


array imagefttext ( resource $image , float $size , float Sangle , int $x , int $y , 
int Scolor , string Sfontfile „string $text [, array Sextrainfo ] ) 

int imageloadfont ( string $file ) 

array imagepsbbox ( string $text , resource Sfont , int $size ) 

array imagepsbbox ( string $text , resource $font , int $size , int Sspace , int 


Stightness , float Sangle ) 


bool imagepsencodefont ( resource Sfont. index , string Sencodingfile ) 


取得 使 用 FreeType 2 字体 
的 文本 范围 
使 用 FreeType 2 字体 将 文 
本 写 入 图 像 
载 入 一 利 





体 


取 得 使 用 PostScript 
Typel 字体 的 文本 范围 








人体 中 的 字 





改变 : 
矢量 





bool imagepsextendfont ( resource Sfont_index , float Sextend ) 


bool imagepsfreefont ( resource $font, index ) 


resource imagepsloadfont ( string $filename ) 


bool imagepsslantfont ( resource $font. index , float Sslant ) 





扩充 或 压缩 字体 

释放 PostScript Typel 字 
体 所 占 的 内 存 

从 文件 中 加 载 PostScript 











array imagepstext ( resource $image , string Stext , resource $font_index , int 
$size , int Sforeground , intS$background , int $x , int $y [, int Sspace = 0 [, int 
Stightness = 0 [, float Sangle = 0.0 [, int Santialias steps = 4 ]]]] ) 


Hj PostScript Typel 字体 把 
文本 字符 串 画 在 图 像 上 





array imagettfbbox ( float $size , float Sangle , string $fontfile , string $text ) 


取得 使 用 TrueType 字体 
的 文本 范围 





array imagettftext ( resource $image , float $size , float Sangle , int $x , int Sy , 
int Scolor , string Sfontfile, string $text ) 





用 TrueType 字体 向 图 像 
写 入 文本 





8.1.4 图 片 缩 略图 
使 用 图 像 缩 略 


























25 














的 目的 就 像 使 用 索引 














样 ， 可 以 让 人 快速 地 了 解 图 像 的 大 致 内 容 ， 在 











T 
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很 多 图 片 网 站 中 ， 都 会 在 上 传 图 片 后 使 用 自动 生成 缩 略图 的 功能 来 制作 这 样 的 索引 。 其 最 
大 的 优势 在 于 节约 网 络 资源 的 占用 ， 加 快 呈现 网 页 的 速度 。 

在 main.php 页 面 中 使 用 的 图 片 可 以 用 原 图 保持 比例 的 缩 略 图 表示 ， 也 可 能 会 根据 页 面 
的 需要 使 用 改变 比例 的 缩 略 图 。 







































































8.2 图像 文 件 的 缩 略 图 的 效果 比较 


/ 
L 
站 PHP 编码 
代码 文件 ，getPIC.php 
(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
Q) 单 击 “代码 ”标签 切换 到 “代码 ”视图 让 输入 如 下 代码 。 
«?php 
/* 函数 功能 二 加 载 图 像 文件 
$4: SfileName 文件 名 
返回 值 : $handle 是 一 个 数字 ，$hanqdle [0] 记录 一 图 像 标 识 符 ， 代 表 了 从 给 定 的 文件 名 取 
得 的 图 像 ，Shandle [1] 记录 错误 的 返回 信息 
kd 
function loadImage ($fileName)( 
$handle-array (NULL, ""); 
if(!file_exists(S$fileName)){// 判 断 文件 是 否 存在 
Shandle [1]=" 错 误 : 文件 ".$fileName. "不 存在 "; 
return $handle; 
) 
Sinfo-getimagesize ($fileName); 
// 返 回 四 元 数组 ，0- 图 像 宽度 ，1- 图 像 高 度 ，2- 图 像 类 型 标记 ，3- 文 本 字符 串 ， 内 容 为 : 
height-"yyy" width="xxx"， 可 直接 用 于 IMG 标记 
switch ($info[2]){ 
case IMAGETYPE GIF: 
break; // 返 回 一 图 像 标识 符 
case IMAGETYPE JEPG: S$handle[0]-8imagecreatefromjepg ($file Name); break; 

















$handle[0]-8imagecreatefromgif ($fileName); 





case IMAGETYPE PNG: Shandle[0]-8imagecreatefrompng ($file Name); break; 





case IMAGETYPE WBMP: $handle[0]-8imagecreatefromwbmp ($fileName) ;break; 
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case IMAGETYPE XBM: Shandle[0]-8imagecreatefromxbm ($fileName) ;break; 


default: Shandle[1]=" 错 误 : 文件 ".$fileName." 不 是 有 效 图 片 格式 或 该 格式 
不 被 当前 GD Wels" ; 
return S$handle; 
) 
if(!Shandle[0])( 
Shandle[1]-"f 


return Shandle; 





文件 " .S£ileName . "格式 被 正确 识别 但 其 内 容 可 能 已 被 破坏 , 无 法 加 载 " 


) 
return $handle; 
5 
/* 函数 功能 ， 生 成 图 片 文件 或 输出 到 页 面 
参数 : SsrcHandle- 图 像 的 标识 , SdestFileName- 目 标 文件 , $defaultType- 缺 省 文件 类 型 
返回 值 :， 凶 辑 true /false 
y 





function imageToFile ($srcHandle,$destFileName-NULL,$defaultType- 
IMAGETYPE JPEG) { 


$rst-true; 
if(SdestFileName!-NULL)|( 
$ary-pathinfo($destFileName); // 文 件 信 
basename, extension, filename 





的 四 元 数组 , 分 别 是 dirname, 


$tep=strtolower ($ary['extension']); 

} 

else( 
$tep-""; 

) 

switch($tep) (//strtolower 函数 把 字符 串 转 换 为 小 写 ，S$ary['extension'] 文件 扩展 各 
case^"gif": $rst-imagegif ($srcHandle,$destFileName);break; // 将 
$srcHandle 创建 以 destFileName 为 名 的 图 像 文件 


Oase "jpg": $rst-imagejpeg ($srcHandle, $destFileName);break; 
case "png": $rst-imagepng ($srcHandle,S$destFileName);break; 
case "wbmp": $rst-imagewbmp ($srcHandle,S$destFileName);break; 
default: 


switch ($defaultType)( 


case IMAGETYPE GIF: if($destFileName--NULL) $rst-Q(imagegif 
($srcHandle) ;// 将 $srcHandle 直接 送 到 浏览 器 





else $rst=@imagegif ($srcHandle, $destFileName); break; 


case IMAGETYPE JPEG: if($destFileName--NULL) $rst=@imagejpeg 
(SsrcHandle); 


else $rst-(imagejpeg(S$srcHandle, $destFileName); break; 
case IMAGETYPE PNG: if($destFileName--NULL) $rst-(imagepng 
(SsrcHandle); 


else $rst-Q(imagepng ($srcHandle,$destFileName); break; 
case IMAGETYPE WBMP: if(SdestFileName--NULL) 


$rst-8imagewbmp 
($srcHandle); 





else $rst-Q(imagewbmp ($srcHandle, $destFileName); break; 
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default: if($destFileName--NULL) $rst=@imagejpeg ($srcHandle); 
else S$rst-(imagejpeg ($srcHandle, $destFileName); break; 


) 


return $rst; 


3 

















文件 , $destPic- 缩 略图 , $destWidth- 缩 略图 的 宽度 , $destHeight- 
缩 略图 的 高 度 , $keepRate- 是 否 保 持 宽 高 比 , $srcX-, $srcY-, $srcWidth- 原 图 的 宽 
度 , $srcHeight- 原 图 的 高 度 
返回 值 : 逻辑 true /false 
sin 
function shrinkMap ($srcPic,S$destPic-NULL,$destWidth-0,$destHeight-0, 
S$keepRate-true,$srcX-0,$srcY-0,$srcWidth-0,$srcHeight-0)( 
Serror-""; $rst-true; 
$srcHandle-loadImage ($srcPic) [0]; XY 调用 方法 加 载 图 像 文 件 
if (S$srcHandle!-NULL)( 
$srcPicInfo-getimagesize ($srcPic); // 获 取 图 像 文件 的 
if($srcWidth«-0) S$srcWidth-$srcPicInfo[0]; 
if(SsrcHeight«-0) SsrcHeight-SsrcPicInfo[1]; 
$WHRate-$srcWidth/$srcHeight; // 设 置 宽 高 比 
// 判 断 缩 略图 大 小 ， 调 整 宽 高 
if($destWidth«-0 && $destHeight«-0)( —//T WW E 
$destWidth-100; 
SdestHeight-SdestWidth/SWHRate; 
) 
else if ($destWidth>0 && $destHeight«-0) $destHeight-$destWidth/SWHRate; 
刀具 设置 宽度 
else if(SdestHeight»0&& $destWidth«-0) $destWidth-$destHeight*SWHRate; 
/7 只 设置 高 度 
else( // 宽 高 都 设置 
if ($keepRate) { // 保 持原 有 比例 
if($destWidth/$destHeight>=$WHRate) $destWidth=$destHeight* $WHRate; 
// 以 高 为 准 
else $destHeight-$destWidth/SWHRate;  // 以 宽 为 准 





























) 
$dstHandle-imagecreate ($destWidth,$destHeight); // 创 建 了 一 幅 大 小 为 x_size 和 
y size 的 空白 图 像 的 标识 符 
if (!@imagecopyresized ($dstHandle, $srcHandle, 0, 0, $srcX, $srcY, SdestWidth, 
S$destHeight,Ssrcwidth,SsrcHeight)){// 将 图 像 SsrcHandle 中 的 一 块 区 域 ($SsrcX, $srcY)， 
$srcWidth, $srcHeight， 复 制 到 图 像 
$dstHandle t} (0, 0) , $destWidth, $destHeight 
$errorText=" 调 整 大 小 过 程 失 败 ， 可 能 参数 有 误 " .$destPic; 
return $errorText; 
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// 生 成 图 片 文件 
if (!imageToFile ($dstHandle, $destPic, $srcPicInfo[2])){ // 将 $dstHandle 
生成 以 $destPic 为 文件 名 ， 以 $srcPicInfo[2] 为 文件 类 型 的 图 像 
$errorText=" 无 法 生成 图 片 " .$destPic; 
return $errorText; 
} 
return true; 
n 
else( $errorText-$error; return false; } 
b 
$srcPic-"water.jpg"; 
Switch($ REQUEST ["type"]) ( 
case "origin": header("Location:$srcPic"); break; // 原 始 图 像 
case "shrinkl": shrinkMap($srcPic, NULL, BOT "MA /7/ 缩 略图 , 保持 比例 
case "shrink2": shrinkMap(S$srcPic, NULL, No false); break; 
// 缩 略图 ， 改 变 比例 QN 
5 


?> 





s 
; Ac 
NS 


(3) 把 文档 以 getPIC.php 为 文件 名 保存 在 站 点 的 extend/ch8 文件 夹 下 


人 


这 段 代码 实现 3 项 功能 : 加 载 图 像 、` 生 成 图 片 文件 或 输出 到 页 面 和 生成 缩 略图 。 
第 6~27 行 : 根据 指定 的 文件 名 SfileName 加 载 图 像 文件 ; 其中: 
第 7 行 : 设置 返回 值 为 数组 .如 函数 说 明 中 的 含义 
第 8~11 行 : 判断 文件 $fileName 是 否 存 在 3 
第 13 ~ 21% 行 : 要 据 文件 类 型 新 建 图 像 . 
第 32 ~ 62 行 ; 把 文件 SsrcHandle 按 文件 类 型 SdefaultType 输出 到 文件 SdestFileName 或 浏览 器 。 其 中 : 
第 33 行 : Srst 记录 函数 返回 值 。 
第 34~ 40 行 : 确定 目标 文件 的 类 型 信息 。 
第 41~59 行 : 根据 获取 的 文件 扩展 名 ， 把 图 像 文件 $defaultType 输出 到 文件 SdestFileName. 
47- 58 行 : 根据 参数 $defaultType， 把 图 像 文件 SdefaultType 输出 到 文件 $destFileName 或 浏览 器 
~ 100 £r: 对 源 文 件 $srcPic 按 缩放 尺寸 (SdestWidth 5, SdestHeight 高 ) 或 宽 高 比 SkeepRate " 出 
到 目标 文件 SdestPic 3 B. Xv: 
第 69 - 98 行 : 成 功 加 载 图 像 文件 SsrcPic 的 处 理 。 其 中 : 
第 71~86 行 : 设置 源 和 目标 图 像 的 宽 、 高 等 参数 。 
第 87~91 行 : 按照 设置 的 参数 调整 图 像 的 大 小 并 复制 部 分 图 像 到 目标 文件 $destPic。 
第 93 ~ 96 行 : 按照 原 图 像 的 格式 重新 生成 输出 图 像 文件 。 
第 99 行 : 当 加 载 图 像 不 成 功 时 ， 返 回 错误 信息 . 
第 101-106 行 : 根据 对 获取 的 请 求 数据 设置 输出 的 图 像 。 


代码 文件 : picRAR.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
D 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 添 加 如 下 代码 。 
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«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<title> 缩 略图 效果 对 比 </title> 


<table width-"460" border-"1" style-"border-collapse:collapse; border:1Px 
#666666 inset; font-size:l2px"» 
«tr» 
«td width-"87" rowspan="2"> 原 始 图 像 <br/><img src-"getPIC.php?type-origin" 
alt=" 原 始 图 像 原始 大 小 "align="left" /></td> 
«td width-"357"»«img src-"getPIC.php?type-shrinkl" alt=" 缩 略图 ， 保 持 比 
例 ”/><br/> <br/> 缩 上 略图， 保持 比例 </td> 


</tr> 
<tr><td><img src="getPIC.php?type=shrink2" BTE IE 改变 比例 " /»«br/» 
<br/> 缩 咯 图， 改变 比例 </td></tr> K 
<tr><td colspan="2"> </td></tr> NAN 
A 
</table> AN 





XN- 
(3) 把 文档 以 picRAR.php 为 文件 名 保存 在 站 点 的 -extend/ch8 文件 夹 下 


82 ”图 像 文件 上 传 处 理 


(ME 
Nep di foin 
8.2.4. 网 站 图 像 存储 策略 


网 站 中 的 图 像 必 须 存储 在 服务 器 上 。 沽 般 地 ， 存 放 图 像 有 两 种 方法 ， 其 一 是 将 图 像 文 
件 直接 存储 在 数据 库 中 ， 其 二 是 使 用 文件 系统 存储 图 像 。 两 种 方法 各 有 优 缺 点 。 

将 图 像 文 件 存储 iban 容易 地 访问 所 有 图 像 信 息 。 例 如 ， 从 数据 库 中 删除 
图 像 只 需要 删除 数据 f ， 而 不 必 删 除 图 像 文件 。 备 份 Web 应 用 更 为 简单 ， 因 为 只 
需要 备份 数据 库 ， Wh Ar 上 传 文件 。 

使 用 文件 / 兼容 性 。 由 于 大 多 数 数据 服务 器 会 使 用 不 同 的 方法 存储 
数据 ， 因 此 对 于 应 -种 类 型 的 数据 库 服务 器 ， 可 能 都 需要 单独 实现 。 对 于 已 经 在 文 
件 系 统 上 的 文件 ， 完 成 文件 操作 会 简单 得 多 ， 如 8.1 节 中 的 创建 图 像 缩 略 图 。 

结合 上 述 两 种 方法 的 特点 ， 将 所 有 图 像 保存 在 文件 系统 中 ， 使 用 一 个 数据 库 表 存储 这 
些 图 像 文件 的 有 关 信息 。 

本 书 案例 的 图 书信 息 中 的 图 书 封面 图 像 和 评价 等 级 图 像 的 存储 路 径 分 别 以 字段 
book pic 和 book level pic 保存 到 数据 表 bookinfo 中 ,图 像 文 件 分 别 存 储 在 webshop/images 
目录 下 的 子 目 录 bookpic 和 level 中 。 在 查询 图 书信 息 时 ， 通 过 提取 文件 名 来 获得 与 图 像 的 

在 对 图 书信 息 的 管理 中 需要 上 传 图 像 文件 到 相应 的 目录 中 ， 同 时 把 文件 名 写 到 数据 表 
bookinfo 对 应 的 字段 中 ， 图 像 文件 的 文件 名 就 是 图 书 的 ISBN。 
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822 上传 图 书 封面 图 像 


一 PR 


首先 要 提供 一 个 表单 ， 需 要 提供 图 书 的 ISBN， 并 从 本 地 机 中 选择 图 像 文件 ， 然 后 传递 
到 指定 的 存放 路 径 上 。 被 传递 的 图 像 要 加 上 网 站 的 Logo 作为 水 印 ， 从 而 对 图 像 进 行 保护 。 
上 上传 图 书 封 面 图像 处 理 的 逻辑 结构 如 图 8.3 所 示 。 


图 书 上: 传 imageload.php 图 像 处 理 类 imageUPload.php 


规划 起 水 页 加 数据 库 基本 捉 作 类 db inc php. 























像 类 image.php 






按钮 


图 8.3 ”上传 图 书 封面 图 像 的 逻辑 结构 
其 中 的 图 像 处 理 类 所 包含 的 属性 和 方法 如 图 8.4 所 示 。 


$_Folder="" s; 
Types- 
$ watertype-l Sai Types-arrayQ 
A $-maxFileSize=1 
$_waterposition=1 . 
$ destinationFolder-"" 


$ waterstring- 
. construct() 

checkfile(Sfile size.Sfile type) 
saveUpFile($file---) 
displayImage(Sdesfile) 


$ waterimg-"" 
$ imgpreviewsize-l 
$ decWight-100 


construct() 


loadImage(SfileName---) 


imageToFile($srcHandle**-) 
shrinkMap($srcPic…) 


markImage($srcPic…) 





图 8.4 图 像 处 理 类 所 包含 的 属性 和 方法 


(99 pups 


1. 图 像 处 理 类 
代码 文件 : image.php、imageUPload.php 


(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
(2) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 添 加 如 下 代码 。 


1 <?php 
2 class imagef 
3 public $ Folder-"";  // 图 像 文件 路 径 
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public $ watertype-l; // 水 印 类 型 (1 为 文字 , 2 为 图 片 ) 
public $ waterposition-1; // 水 印 位 置 (1 为 左下 角 , 2 为 右 下 角 , 3 为 左上 角 ,4 为 
右上 角 , 5 为 居中 ) 

















public $ waterstring-""; // 水 印字 符 串 

public $ waterimg=""; // 水 印 图 片 

public $ imgpreviewsize=1; // 缩 略图 比例 

public $ decWight-100; // 缩 略图 高 度 
J** 


* 函数 功能 : 构造 函数 ， 初 始 化 公共 属性 
£j 
public function _construct(){ 
$this-» Folder 
$this-» watertype-2; 





-./webshop/image/bookpic/"; 


$this-» waterposition-1; 
$this-» waterstring-"wuyabook.com.cn"; 
$this-» waterimg-"images/stamp.gif"; 
$this-» imgpreviewsize-1/2; 
Sthis-» decWight-100; 

) 

/* 函数 功能 ;加 载 图 像 文件 
参数 : $fileName 文件 名 
返回 值 ，$handle 是 一 个 数组 ,$handle [0] 记录 一 图 像 标识 符 ， 代 表 了 从 给 定 的 文件 名 取 





得 的 图 像 ，Shandle [1] 记 录 错 误 的 返回 信息 
v 
function loadImage($fileName) { 
// 见 get PIC.php 中 相应 的 部 分 
) 
j** 


* 函 数 功 能 : 生成 图 片 文人 
* 参 数 说 明 : $srcHandle: 要 保 
NULL 则 输出 到 页 面 ; 
$defaultType: 当 无 法 根据 扩展 名 确定 图 片 文件 格式 时 ， 根 据 此 值 判断 ， 默 认为 jpeg; 
可 选 值 为 IMAGETYPE_GIF、IMRAGETYPE JPEG, IMAGETYPE PNG, IMAGETYPE WBMP 等 
* 函 数 结果 :成 功 返 回 TRUE， 和 否则 返回 FALSE 
sy 
public function imageToFile ($srcHandle, $destFileName-NULL, $defaultType= 
IMAGETYPE JPEG) { 
// 见 getPIC.php 中 相应 的 部 分 





存 成 文件 的 图 片 句柄 ，$destFileName :要 保存 成 的 文件 名 ， 


J** 
* 函数 功能 : 生成 缩 略 图 
* 参数 说 明 : $srcPic: 源 图 片 文件 名 
$destPic: 要 生成 的 新 缩 略 图 文件 名 ,扩展 名 决定 其 生成 的 文件 类 型 ， 默 认为 
jpeg， 如 果 为 NULL， 则 直接 输出 到 页 面 ; 
$destWidth: 缩 略图 宽度 $destHeight : 缩 略 图 高 度 ; 
$keepRate: 是 否 保 持原 有 图 片 比例 。 如 果 为 TRUE， 则 根据 $destwidth 或 
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$destHeight 及 $srcWidth 与 SsrcHeight 的 情况 来 判 


不 变 。 如 果 为 FALSE， 则 可 能 生成 不 同比 例 的 缩 略 图 ; 
SsrcX:jl 


Wr 





生成 的 高 与 宽 并 保持 原 有 比例 





图片 选区 的 左边 距离 ，$srcY: 源 图 片 选区 的 上 边 距离 ; 
$srcWidth: 选 区 的 宽度 ， 大 于 0 的 值 ，<=0 WRA 





用 源 图 片 宽度 ; 
$srcHeight :选区 的 高 度 ， 大 于 0 的 值 ，<=0 则 表示 采用 源 图 片 高 度 。 
* 函数 结果 : $errorText: 取 布尔 值 ， 信 息 生 成 则 返回 TRUE; 否则 返回 FALSE 








zy 














function shrinkMap ($srcPic,$destPic-NULL,$destWidth-0, $destHeight-0, 
SkeepRate-true, 
$srcX-0,$srcY-0,$srcWidth-0,$srcHeight-0)( 
// 见 getPIC.php 中 相应 的 部 分 
) 
J** 
* 函数 功能 : 为 图 片 添加 水 印 
* 参数 说 明 ，@S$srcPic: 源 图 片 文件 名 * es$alpha: 印 章 透 明度 
* 函数 输出 :生成 则 返回 TRUE, 否则 返回 FALSE 并 可 通过 &$errorText 检查 错误 原因 
SA 


public function markImage ($srcPic,S$alpha-30,&S$errorText-"")( 
$rst-true; 


if (S$srcHandle-loadImage ($srcPic,$errorText))( 
$srcPicInfo-getimagesize($srcPic); 
if(file exists($this-» waterimg))[ 


// 用 图 片 水 印 
if(S$markHandle=leadImage ($this-» waterimg,S$errorText))( 


$markPicInfo-getimagesize($this-» waterimg); 
imagecopymerge ($srcHandle, $markHandle,$srcPicInfo[0]* 0.5, 
$srcPicInfo[1]*0.5,0,0, $markPicInfo[0],$markPicInfo[1],$alpha); 

} 

elsel 


S$errorText=" 印 章 图 片 无 法 打开 :" . $errorText; 
return false; 


) 
else( // 用 文字 水 印 


$textcolor=imagecolorallocate ($srcHandle,255,0,0); // 印 章 文本 参考 色 
$fontSize-5; // 印 章 文本 字体 大 小 1-5 
imagestring ($srcHandle, $fontSize, $srcPicInfo[0]*0.5, $srcPicInfo 

[1]*0.5, $this-> waterimg, $textcolor); 

} 

if (!imageToFile ($srcHandle, $srcPic)){ // 生 成 图 片 文 件 
$errorText=" 无 法 生成 图 片 " .$srcPic; 
return false; 

} 

return true; 

} 


else( 





SerrorText=" 原 始 图 片 无 法 打开 :" . $errorText; 
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return false; 





(3) 把 文档 以 image.php 为 文件 名 保存 在 站 点 的 webshop/admin/include 文件 夹 下 。 
(4) 在 Dreamweaver 中 ， 新 建 PHP X 
(5) 单 击 “ 代 码 ” 标 切换 到 “代码 


<?php 
require once('image.php'); 





i. 


视图 ， 添 加 如 下 代码 。 





class uploadImage extends image( 





public $ upTypes-array(); // 上 传 文件 类 型 列表 
public $ maxFileSize-1; // 上 传 文件 大 小 限制 :单位 为 Byte 
public $ destinationFolder-""; // 上 传 文件 路 径 
J** 
* 功 能 ， 构造 函 数 ， 初 始 化 公共 属性 
public function construct ()í 


parent:: construct(); X/ 加 载 父 类 构造 函数 
$this-» upTypes-array ('image/jpg', 'image/jpeg', 'image/png', 'image/gif', 
' image/pjpeg', 'image/x-png"); 
$this-» maxFileSize-5000000; 
$this-» destinationFolder-"../imageés/bookpic/"; 
) 
j** 
* 功 能 ， 检 查 土 传 文件 的 合法 性 
* 参 数 说 明 :JSfile_size 文件 的 大 小 ASfile_type 文件 的 类 型 
* 函 数 输出 : 合法 则 返回 TRUE, 否则 返回 相应 的 反馈 信息 
SA 
public function checkfile ($file size,$file type){ 
$msg=true; 
if ($this->_maxFileSize<$file_size){ // 检 查 文件 大 小 
$msg=" 文 件 太 大 ! "; 
return $msg; 
exit; 
} 
if(!in_array ($file type, $this->_upTypes)){ // 检 查 文件 类 型 
$msg=" 只 能 上 传 图 像 文件 ! n; 
return $msg; 
exit; 
) 


return $msg; 


[** 
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* 参 数 说 明 : Sfile 源 文件 , $filename 临时 文件 名 ,S$desfile 目标 文件 名 , Soverwrite 
LX Pr Pul 
* 函 数 输出 :成功 则 返回 TRUE, 否则 返回 相应 的 反馈 信息 
xy 
public function saveUpFile ($file, $filename, $desfile, $overwrite=true) { 
$msg-true; 
if(!file exists($this-» destinationFolder)) 
mkdir(Sthis-» destination Folder); 
$image size-getimagesize ($filename); 
$pinfo=pathinfo ($file); Sftype-Spinfo['extension']; 
$destination=$this->_destinationFolder.$desfile.".".$ftype; 
if (file_exists ($destination) && S$overwrite!=true){ 
Smsg=" 同 名 文件 已 经 存在 了 ! n; 
return $msg; 
exit; 
) 
if(!move uploaded file ($filename,$destination))( 
Smsg=" 移 动 文件 出 错 ! n; 
return $msg; 
exit; 
) 
// 特 加 水 印 效果 


$iinfo-getimagesize($destination); 





$nimage-imagecreatetruecolor($image size[0],S$image size[1]); 
$white-imagecoloórallocate ($nimage,255,255,255); 
$black-imagecolorallocate ($nimage,0,0,0); 
$red-imagecolorallocate ($nimage,255,0,0); 
imagefill($nimage,0,0,$white); 
Switch (Siinfo[2])( 
case 1: S$simage-imagecreatefromgif ($destination); break; 
case 2: $simage-imagecreatefromjpeg($destination); break; 
case 3: $simage-imagecreatefrompng ($destination); break; 
case 6: $simage-imagecreatefromwbmp ($destination); break; 
default: $msg=" 不 能 上 传 此 类 型 文件 ! "; return $msg; exit; 











} 
imagecopy ($nimage, $simage, 0,0,0,0,$image size[0],$image size[1]); 
switch ($this->_watertype) { 
case 1: imagestring ($nimage, 5, 0, $image_size[1]-15, $this->_waterstring, 
$red); 
break; ”// 加 水 印字 符 串 
case 2: $simagel=imagecreatefromgif ($this-» waterimg); 
$sinfo-getimagesize($this-» waterimg); 
imagecopymerge ($nimage, $simagel, ($image size[0]-$sinfo[0])/2, 
(Simage size[1]-$sinfo[1])/2,0,0, $sinfo[0], $sinfo[1],50); 
imagedestroy ($simagel); 
break; // 加 水 印 图 片 
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) 
switch ($iinfo[2]){ 
case 1: imagegif($nimage, $destination); break; 
case 2: imagejpeg ($nimage, $destination); break; 
case 3: imagepng($nimage, $destination); break; 
case 6: imagewbmp(Snimage, $destination); break; 
) 
// 覆 盖 原 上 传 文件 
imagedestroy($nimage); imagedestroy ($simage); 
$pinfo-pathinfo(Sdestination); S$fname-$pinfo['basename']; 
$msg-$this-» destinationFolder.$fname; 
return $msg; 
) 
J** 
* 函 数 功能 :显示 上 传 图 像 信 息 
* 参 数 说 明 :$srcPic: 源 图 片 文件 名 *$alpha :印章 透明 度 
* 函 数 输出 :生成 则 返回 TRUE, 否则 返回 FALSE 并 可 通过 &$errorText 检查 错误 原因 
E 
public function displayImage ($desfile)( 








$msg-""; 
if (file exists($desfile))| 
$image size-getimagesize (Sdesfile); 
$whrate-S$image size[0]/Simage size[l]; 
$msg-" JE :".Simage size[0]." 长 有 «Simage size[1]."«br /> 图 片 预 
bE /»"; 





date default timezone set('UTC'); 
$Sdnow-getdate () ; 


S$nowtime-Sdnow['year']."-".$dnow['mon']."-".S$dnow['mday']."  ".S$dnow 
['hours'*].":".$dnow['minutes'].":".$dnow['seconds']; 

$msg.-"«a href-'".$desfile."' target-' blank'»«img 
src-'".$desfile."' height-'100' width-'".(100*$whrate); 

$msg.-"' alt=' 图 片 预览 :\r 文件 名 : ".$Sdesfile."Nr 上 传 时 间 :" .Snowtime."'> 


</a>"; 
$msg.-"«br /> 上 传 时 间 :" .Snowtimey 
return $msg; 
) 


return $msg; 





(6) 把 文档 以 imageUPload.php 为 文件 名 保存 在 站 点 
2. 上传 文件 表单 及 其 处 理 

代码 文件 ，imageload.php 

(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 





i 的 webshop/admin/include 文件 夹 下 。 


‘© 
最 上 
"M 
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«?php 


> 


“代码 ”标签 ， 切 换 到 “代码 ”视图 ， 添 加 如 下 代码 
require once('include/imageUPload.php'); 
$imagefile-new uploadImage(); // 创 建 上 传 图 像 对 象 
$msg2-""; 


$ps-"";$desfile-"";$upfile-""; 

if(isset($ POST['upload'])) $ps-$ POST['upload']; 

if(isset($ POST['isbn'])) $desfile-$ POST["isbn"]; // 获 取 提交 表单 数据 

if(isset($ FILES['upfile'])) $upfile=$_FILES["upfile"]; // 获 取 提 交 表 单数 据 

if($ps== "上传 图 像 文件 ') ( 

if (!is uploaded file($ FILES['upfile']['tmp_name'])){ // 判 断 文件 是 否 是 通 
过 POST 上 传 的 
$msg-"«font color='red'> 文 件 不 存在 ! «/font»"; 


exit; 
} 
$file=$upfile; // 获 取 源 文件 
$file size=$file["size"];$file type-Sfile["type"]; // 获 取 源 文件 的 大 小 和 类 型 
$filename=$file["tmp name"]; / /获取 源 文件 的 临时 文件 


$imagefile=new uploadImage (); 
$msg-Simagefile-»checkfile(Sfile size, $file type); ”// 检 查 文件 是 否 适合 上 传 
if ($msg==true && Sdesfile!-"")( 
$msgl-$imagefile-»saveUpFile ($file["name"],$filename, $desfile); 
$msg2-" HARI Eff«br» 3c E: ".$msgl."«br/»"; 





) 
if($msgl!-"") $msg2.-$imagefile-»displayImage (Smsg1) ;// 上 传 到 指定 路 径 


// 处 理 写 入 数据 表 bookinfo (Wf) 


«!DOCTYPE-html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 

<head> 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 上 传 图 书 封面 图 像 </title> 
<link href="./css/bscss.css" rel="stylesheet" type="text/css" /> 


</head> 
<body> 


<div id="appb"> 
«div id="bt"> 上 传 图 书 封面 图 像 <hr/></div> 
<form action="" method="post" enctype="multipart/form-data"> 
«table width-"600" border-"0" class="tdl"> 
«tr»«td»[d-B ISBN«/td»«td»«input type="text" name-"isbn" size-"45" 


value-"" /»«/td» 





«td»«input type-"hidden" name-"isbnl" value-"" /»«/td»«/tr» 
<tr><td> 选 择 图 像 文 件 </td><td><input type-"file" name-"upfile" id= 


"upfile" size- "45"/»«/td» 
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<td><input type="submit" name-"upload" value=" HREF" /> 
</td></tr> 
<tr><td colspan-"3" id-"bb" align="center"> 人 允许 上 传 的 文件 类 型 为 :jpg 
| jpeg | png | pjpeg | gif | bmp |x-png«/td»«/tr» 
<tr><td colspan-"3" class-"td2" align-"center"»«?php echo $msg2; ?> 
</td></tr> 
</table> 
</form> 
</div> 
</body> 
</html> 


(3) 把 文档 以 imageload.php 为 文件 名 保存 
3. 调试 图 书 封面 图 像 上 传 








点 的 webshop/admin 文件 夹 下 。 


(1) 确认 存放 imageUPload.php、imageUPload.php 和 imageload.php 的 文件 夹 已 存放 在 
服务 器 访问 目录 (如 cNAppserv www wuya 或 c:\htdocs\wuya) 下 。 

(2) 启动 浏览 器 ， 输 入 : http://localhost/wuya/webshop/admin/imageload.php， 单 击 “ 转 
到 ”按钮 ， 可 见 如 图 8.5 所 示 的 效果 。 


土 传 图 书 封面 图 像 


AES) (EE 


入 序 放 下 信 的 文件 闫 型 为 jpe lipo [pne] Poel of lomp |xpne 





图 8.5 上 传 图 书 封面 图 像 页 面 


(3) 在 图 8.5 所 示 的 页 面 中 填写 “图 书 ISBN”， 单 击 “ 浏 览 ” 按 钮 出 现 如 图 8.6 所 示 的 
对 话 框 ， 选 择 需 要 的 文件 。 


选择 文件 





xix 


z 
s 


RE 





XE) Trorszireser. jve 


asao: [Ekeot*no o —— s] 








图 8.6 “选择 文件 ”对 话 框 
(4) 在 图 8.5 所 示 的 对 话 框 中 单 击 “ 上 传 图 像 文件 ”按钮 ， 出 现 如 图 8.7 所 示 的 界面 。 


















































(Q we mms PHP 的 高 级 功能 
o ES o TS 


上 传 图 书 封面 图 像 








郊 放 上 全 的 文 伯 基 到 为 gliprglFnglppvgl efl toe] oz. 
[m 








ABE fogskcokgeTETRQUS ST ipe. 
pamore 
D 





图 8.7 图 像 上 传 后 的 界面 
(5) 在 webshop/image/bookpic 文件 夹 中 可 以 看 到 新 添加 的 图 像 文件 。 
8.23 PHP 文件 上 传 处 理 


PHP 在 本 机 同时 支持 FTP 和 HTTP 上 传 ， 可 usse Qus mota. 

1. HTTP 上 传 NN 

HTTP 上 传 包括 POST 方法 上 传 和 PUT 方法 Kir 方法 上 传 提 供 对 Netscape 
Composer 和 W3C Amaya 等 客户 端 使 用 的 H PEUIM. 对 于 POST 方法 上 传 ， 
8.2.2 节 案 例 给 出 代码 和 效果 。 这 里 ， A ASA d 中 的 关键 代码 。 

1) 表单 部 分 

第 38 行 ， 设置 属性 ， 即 enctype = emen meo Us POST. 

第 41 行 : 隐藏 域 isbnl， RES IN 的 值 p; 

2) 处 理 上 传 文件 $ 2 

第 10 £5. 使 用 函数 Au file 0 判断 E POST 上 传 的 。 


bool is "m file ( scing iEn 


如 果 filenam 给 出 的 文件 是 通过 HTTP POST 上 传 的 ， 则 返回 TRUE， 可 以 用 来 确 
SERE RR CSS d 问 不 能 访问 的 文件 。 


588, 14 行 ， 上 传 时 ，PHP 收 到 关于 该 文件 的 信息 ， 这 些 信息 记录 在 超 全 局 数组 $_FILES 中 。 

第 18 行 ， 通 过 类 方法 checkfile 检查 文件 大 小 是 否 超出 了 预 设 的 大 小 限制 ， 文 件 类 型 是 否 为 预 设 定 类 型 。 

第 20 行 : 通过 类 方法 saveUpFile 把 文件 存储 到 指定 的 目录 下 。 

第 23 行 ， 通过 类 方法 displayImage 显示 上 传 的 图 像 信 息 。 

而 在 imageUPLoad.php 中 的 方法 saveUpFile 的 第 52 行 中 使 用 了 函数 move_uploaded_file() 
实现 移动 上 传 的 临时 文件 到 指定 的 目录 : 

bool move uploaded file(string filename, string destination) 

函数 的 功能 : 检查 并 确保 由 filename 指定 的 文件 是 合法 的 上 传 文件 ( 即 通过 PHP 的 HTTP POST 上 传 
机 人 制 所 上 传 的 )。 如 果 文 件 合法 ， 则 将 其 移动 为 由 destination 指定 的 文件 。 

如 果 filename 不 是 合法 的 上 传 文件 ， 就 不 会 出 现任 何 操作 ，move_uploaded_file0 将 返回 FALSE. 


如 果 filename 是 合法 的 上 传 文件 , 但 出 于 某 些 原因 无 法 移动 , 也 不 会 出 现任 何 操作 , move, uploaded. file() 
将 返回 FALSE。 此 外 还 会 发 出 一 条 和 警告。 





name ) 
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超 全 局 数组 8$ FILES 


超 全 局 数组 $_FILES 是 一 个 形 如 8_FILES[keyl][key2] 的 二 维 数组 ， 其 中 keyl 指出 文件 名 称 ， 如 
本 案例 的 "upfile'，key2 的 取 值 如 下 . 

'mame': 客户 端 机 器 文件 的 原名 称 。 

"type: 文件 的 MIME 类 型 ， 需 要 浏览 器 提供 该 信息 的 支持 ， 如 “image/jpg”。 

'size': 已 上 传 文件 的 大 小 ， 单 位 为 字 节 


'tmp name: 文件 被 上 传 后 在 服务 端 储存 的 临时 文件 名 ， 不 包含 文件 扩展 名 。 
'error:. 和 该 文件 上 传 相关 的 错误 代码 。$_FILES[upfile']['error] 的 取 值 如 下 。 
UPLOAD ERR OK 或 0: 没有 错误 发 生 ， 文 件 上 传 成 功 。 
UPLOAD ERR INI SIZE 或 1: 上 传 的 文件 超过 了 php.ini 中 upload_max_filesize 选项 限制 的 值 。 
UPLOAD ERR FORM SIZE 或 2: 上 传 文件 的 大 小 超过 了 HT] 表单 中 MAX_FILE_SIZE 
选项 指定 的 值 。 / YA 
š " NON 
UPLOAD ERR PARTIAL 3,3: 文件 只 有 部 分 被 上 传 和 ~ 





3) pbpiini 中 与 文件 上 传 相关 参数 x 








file_uploads 是 耕 允 许 上 传 文件 ， i 

upload tmp dir “上传 文件 放 惫 未 指定 则 使 用 认 位 置 。 

upload_max_filesize “允许 小 的 最 大 值 ， 默 

post max. size ream 所 能 接受 的 最 大 数据 量 ， 如 果 希 望 
用 PHP 文件 上 传 ， 则 此 值 要 改 为 比 upload_max_filesi 

max_input_time. 以 秒 为 单位 对 通过 POST 限制 。 

memory [i ET 系统 内 存 ，PHP 允许 定义 内 存 使 用 限额 。 通 过 设 
was ty 程序 可 以 使 用 的 最 大 内 存 容量 ， 应 适当 大 于 post max size 值 。 


max execution time 用 来 设置 在 强制 终止 脚本 前 PHP 等 待 脚本 执行 完毕 的 时 间 ， 单 位 为 秒 。 此 选 
项 可 限制 死 循 环 脚本 ， 但 当 存 在 一 个 长 时 间 的 合法 活动 时 (如 上 传 大 文件 )， 这 项 功能 也 会 导致 操作 失败 。 
这 种 情况 下 必须 考虑 将 此 变量 增加 。 


4) 上 传 多 个 文件 
利用 $_FILES 数组 可 以 轻松 实现 多 文件 上 传 。$_FILES 数组 可 以 获取 客户 端 表单 里 面 
所 有 的 file 域内 容 ， 从 而 获得 所 有 在 同一 表单 上 传 的 文件 。 

















<form action-"file-upload.php" method="POST" enctype-"multipart/form-data"» 
Send these files:«br» 
<input name-"userfile[]" type-"file"»«br» 
<input name-"userfile[]" type-"file"»«br» 
<input type="submit" value-"Send files"> 
</form> 


当 以 上 表单 被 提交 后 ， 数 组 $_FILES['userfile]、$_FILES['userfile"][mame'] 和 $_FILES 
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[userfile]['size] 被 初始 化 :如果 register_globals 的 设置 为 on， 则 和 文件 上 传 相 关 的 全 局 变 
量 也 将 被 初始 化 。 所 有 提交 的 信息 都 将 被 存储 到 以 数字 为 索引 的 数组 中 。 

例如 ， 假 设 名 为 image.jpg 和 image.gif 的 文件 被 提交 ,， 则 $_FILES[userfile][mame'][0]= 
imagel.jpg， 而 $_FILES[userfile][mame'][1]=image.gif。 类 似 地 ，$_FILES[userfile][size'][0] 
是 文件 imagel.jpg 的 大 小 ， 依 此 类 推 。 





HTTP 上 传 文件 的 局 限 


一 般 来 讲 。 通过 Internet 上 传 文件 ， 并 不 是 一 种 很 好 的 办 法 ， 主 要 原因 如 下 。 

(1) RTE. 如 果 未 完成 文件 上 传 ， 则 无 法 恢复 上 传 ， 这 说 明 大 文件 可 能 根本 无 法 上 传 。 另 外 ， 
如 果 一 段 时 间 内 没有 其 他 动作 ， 有 些 浏览 器 可 能 会 认为 出 现 了 一 个 错误 ， 这 通常 会 导致 为 用 户 显示 
一 个 错误 消息 ， 

D 有 限制 上 传 一 个 文件 时 ， 如果 不想 中 断 上 传 ， ry 

O 笨拙 ， 出 于 安全 性 考虑 ,文件 上 传 表单 的 功能 往往 有 些 受 限 % 例如， 运用 到 文件 输出 的 样式 
通常 很 少 ， 另 外 ， 文 件 输入 只 允许 单 选 ， 这 说 明 用 户 无 法 一 as ul 个 文件 (如 果 表 单 允 许 有 多 个 文 
件 输入 ， 则 必须 同时 选择 这 些 文件 )。 

(4) 不 能 提供 充分 的 信息 。HTTP Re 这 说 明 ， 无 法 很 容 
易 地 知道 上 传 完成 了 多 少 ， 以 及 还 需要 多 长 时 间 才 能 XA. 


2. FTP 上 传 YS- 


PHP 也 可 以 实现 FTP 上 传 。 Sa f siue PHP 程序 再 将 其 传输 到 FTP 
服务 器 上 。 这 党 要 使 用 PHP f TP AA- 步骤 如 下 3 

(1) 确信 拥有 连接 人 上 传 到 服务 器 的 权限 。 因 为 LOPP ARRES FT M AE 
接 ,所 以 需要 确信 拥有 下 TP 的 信任 书 。 可 以 通过 全 用 令 行 的 FTP 客户 端 登录 到 目标 服务 
RE ARERIA EIE PEIE 


4p 
$ftp 
ftp> open some.host.com 


Connected to some.host.com. 





220 Welcome to leon FTP Server! 

User: upload 

331 User upload okay, need password. 

Password: ****** 

230 Restricted user logged in. 

ftp»bin 

200 Type okay. 

ftp»hash 

Hash mark printing On?ftp: (2048 bytes/hash mark) . 
ftp»put file.bin 

200 PORT command successful. 

150 Opening BINARY mode data connection. 

Hn 

226 Transfer completed. 

ftp: 4289 bytes sent in 0.00Seconds 4289000.00Kbytes/sec. 








b, 


PHP 动态 网 页 设计 与 制作 案例 教程 (第 = 版 ) o 


ftp» bye 
221 Goodbye. 


(2) 创建 上 传 表单 。 创 建 HTML 表单 ， 向 用 户 询问 重要 的 参数 : FTP 服务 器 的 访问 信 
息 、 服务器 上 传 的 目录 , 以 及 完整 的 目录 和 上 传 文件 的 名 字 。 例如 , 文件 名 为 fpupfilthtml。 


示例 8-4 FTP 上传 ftpupfilt.html 
<html> 
<body> 
<h2> 请 提供 下 列 信息 : </h2> 
<form enctype-"multipart/form-data" method="post" action-"upload.php"» 
<input type="hidden" name-"MAX FILE SIZE" value-"5000000" /> 
主机 Host «br /»«input type="text" name-"host" /»«p /> 
用 户 名 <br /»«input type="text" name-"user" /»«p /> 工 
密码 <br /><input type-"password" name-"pass" Be 
目标 目录 «br /><input type="text" name="dir" /> / 
上 传 文件 <br /> «input type="file" name-"file" X><P /> 
«input type-"submit" name-"submit" NN 文件 ” /> 
</form> SE 
</body> ANS 
</html> n XXV 
(3) 创建 PHP 上 传 处 理 程序 。 T PHP 的 FTP 函数 按照 用 户 提供 的 访问 信任 书 把 它 伟 
输 到 目标 服务 器 上 。 VX i 








示例 8-4 FTP 上 传 文件 之 表单 处 理 程序 upload.php 


«?php x 
// 表 单 处 理 程序 PRIoaa Php SS 


$host-$ NN ]; $user- sien ser']; 
dni a pass']; $destDi -5$ POST[' el // 获 取 FTP 访问 参数 





E E SEES ] // 定 义 本 地 系统 
$tmpName-basename($ FILES['file']['tmp name']); // 获 取 上 传 文件 的 临时 文件 名 
move uploaded file($ FILES['file']['tmp name'], $workDir."/".$tmpName) or 
die ("不 能 把 上 传 文件 移动 到 工作 目录 ! ") 7 // 复 制 上 传 文件 到 当前 目录 
$conn-ftp connect($host) or die ("Cannot initiate connection to host"); 
// 打 开 FTP 连接 


ftp_login($conn, $user, $pass) or die ("不 能 登录 ! "); ”// 发 送 访问 参数 
$upload=ftp put ($conn,$destDir."/".$ FILES['file']['name'],$workDir. 


"/".$tmpName,FTP BINARY); // 实 现 文件 上 传 
if(!$upload) echo "不 能 上 传 ! "; else echo "上 传 完成 ! ";  ”// 检 查 上 传 状态 ， 显 示 信息 
ftp close ($conn); // 关 闭 FTP 


unlink($workDir."/".$tmpName) or die("Cannot delete uploaded file from 
working directory -- manual deletion recommended"); // 删 除 上 传 文件 的 本 地 副本 
2 

















函数 ftpp_connect0 和 ftp_login0) 用 来 初始 化 指定 的 FTP 主机 的 连接 , 并 使 用 提供 的 信任 
书 登录 。 
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resource ftp_connect(string host[,int port[,int timeout]]) 
函数 的 功能 : 如 果 成 功 ， 则 返回 一 个 连接 标识 ， 如 果 失 败 ， 则 返回 FALSE. 
参数 host 为 要 连接 的 服务 器 。host 后 面 不 应 以 斜 线 结 尾 ， 前 面 也 不 需要 用 ftp:// 开 头 。 
可 选 参数 port 为 要 连接 到 的 FTP 器 的 端口 号 ， 如 果 设置 为 0， 则 会 按照 默认 端口 21 连接 。 
可 选 参数 timeout 用 来 设置 网 络 传输 的 超时 时 间 限 制 。 如 果 FTP 服务 器 软件 为 omitted， 则 默认 的 值 为 
超时 时 间 可 以 在 任何 时 候 通过 函数 fp_set_option0 和 ftp_get_option() 来 改变 或 修改 。 
bool ftp_login(resource ftp stream,string username,string password) 
函数 的 功能 : 使 用 用 户 名 和 密码 登录 给 定 的 FTP 连接 。 
如 果 登 录 成 功 ,就 使 用 fp_putO 函 数 把 文件 从 工作 目录 上 传 到 用 户 指定 的 远程 目录 里 ， 
并 把 它 的 名 字 改 回 原来 的 名 字 。 


bool ftp_put(resource ftp stream,string remote file,string local file, int — „int startpos]) 


函数 的 功能 : 用 来 上 传 由 local_file 参数 指定 的 文件 到 FTP E 卡 传 后 的 位 置 由 remote. file 指定 。 
传输 模式 参数 mode 只 能 为 FTP_ASCII( 文 本 模式 ) 或 FTP_BINAR 让 模式 )。 


上 传 完成 后 ， 使 用 ftpp_close() 函 数 断 开 与 SS 
void ftp_close(resource ftp stream) 


函数 的 功能 : 关闭 一 个 由 参数 fp_: K Ta 接 并 释放 所 占用 的 资源 。 使 用 此 函数 后 将 不 能 再 使 
用 当前 的 FTP 连接 ， iiS j 次 使 用 ftp_connect() 函 数 来 建立 一 个 新 的 连接 。 


8.3 En 


(S nates gr x 
b^ x Ka 
r 

8.3.1 PHP SS 

PHP 脚本 要 想 发 送 电子 邮件 ， 首 先 要 让 PHP 与 邮件 服务 程序 建立 联系 ,知道 邮件 服务 
程序 的 全 或 互联 网 地 址 。 一 般 来 说 ， 本 地 的 “互联 网 服务 供应 商 (ISP)” 会 提供 这 些 信 息 。 
楼 下 来 ， 需 要 更 新 php.ini 文件 里 SMTP 属性 的 设置 ， 让 它 指向 这 个 服务 器 。 这 个 属性 的 默 
认 值 是 localhost( 所 有 基于 UNIX 操作 系统 的 计算 机 都 已 经 在 IP 地 址 127.0.0.1 安装 了 邮件 
民 务 程序 。 但 Windows 没有 默认 的 本 地 邮件 服务 程序 )。 
PHP 实现 邮件 的 发 送 有 两 种 方式 : 使 用 PHP V TOU mail0) 函 数 和 使 用 封装 SMTP 协议 
的 邮件 类 。 
过 去 ， 任 何 邮 件 服务 程序 都 会 接受 由 任何 人 发 送 给 任何 人 的 任何 消息 ， 但 由 于 垃圾 邮 
件 滥用 了 这 种 规则 ， 现 在 几乎 全 部 邮件 服务 程序 都 进行 了 保护 ， 如 进行 身份 验证 ， 要 求 使 
用 用 户 名 和 密码 访问 邮件 服务 程序 。PHP 扩展 和 应 用 库 (PEAR) 的 邮件 程序 定义 了 发 送 邮件 
的 一 个 接口 和 很 多 函数 。 当 然 ， 也 可 以 建立 自己 的 邮件 服务 程序 来 处 理 邮 件 发 送 请 求 。 
本 章 案例 中 介绍 了 PHP. 实现 邮件 的 发 送 有 两 种 方式 , 可 以 对 本 书 案例 实现 使 用 电子 邮 
件 向 用 户 发 送信 息 。 一 旦 订单 被 处 理 ， 及 时 通知 客户 接收 图 书 。 也 可 以 批量 发 送 邮 件 ， 向 
会 员 推 荐 最 新 图 书 、 热 门 图 书 、 降 价 图 书 等 消息 。 





90s。 
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8.82 ”向 客户 发 送 邮 件 


[œ 


(V sert 

1. 配置 SMTP 服务 器 

(1) 下 载 一 个 免费 的 SMTP 服务 器 ， 并 运行 它 。 

(2) 修改 其 中 的 参数 ， 如 把 本 机 当前 地 址 修改 为 127.0.0.1。 

G) 单 击 “ 开 始 ”|“ 运 行 ”命令 ,输入 cmd， 打 开 “ 命 令 提 示 符 ”窗口 ， 发 送 一 份 邮 
件 ， 测 试 SMTP 服务 器 的 状态 (黑色 为 输入 文字 ， 灰 色 为 系统 显示 文字 )。 





Cr>telnet 
Microsoft Telnet>open localhost 25 E 
220 SMTP Server Ready // 打 开 一 个 新 窗口 K 


250 SMTP XXX,please meet you 
mail from: <alianf@localhost.com> ,站 
250 OK Send to "alianf@localhost. UNS llowed 


Helo alfang SN 


rcpt to: alianfücitiz.net 
250 OK Sender "alianfGlocalhost: E) allowed 


DATA S4- 


354 Start mail input;en Ae <CRLF>" 






alfang: 你 好 ! 这 只 是 一 JL dian W 
250 OK Sir-Y Xi Wx 
Quit 


221 thinks for have a nice dày^ WX 


常用 的 SMTP 命令 如 表 8.8 所 示 。 


表 8.8 常用 的 SMTP 命令 


HELLO domain 介绍 自己 
MAIL FROM reverse-path 指明 发 件 人 
RCPTTO forward-path 指明 收 件 人 
DATA 确认 邮件 内 容 ( 前 3 TA To, From 和 邮件 主题 ) 
RSET 重 置 
NOOP 要 求 接收 SMTP 仅 做 OK 应 答 (用 于 测试 


QUIT 退出 进程 


























2. 修改 php.ini 中 与 电子 邮件 相关 的 属性 
打开 php.ini， 修 改 其 中 的 代码 (黑色 为 修改 后 的 文字 ， 灰 色 为 原 有 文字 )。 
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© p NE 


[mail function] 

; For Win32 only. 

SMTP = localhost (or IP of LAN or smtp of ISP e.g. 163.com) 

smtp port - 25 

; For Win32 only. 

sendmail_from -"adminGlocalhost.com" 

; For Unix only. You may supply arguments as well (default: "sendmail -t -i"). 
¡sendmail path = 

; Force the addition of the specified parameters to be passed as extra parameters 
; to the sendmail binary. These parameters will always replace the value of 
; the 5th parameter to mail(), even in safe mode. 
;mail.force extra parameters = 


n qe 


© 基于 UNIX 的 系统 中 ，SMTP 默认 为 localhost; 对 于 Win: 置 STMP， 可 以 是 自己 配置 的 
SMTP: localhost， 或 局 域 网 上 SMTP 的 IP, S ISP 的 服务 器 ， AY com. 

Q smtp_port 设置 STMP 的 端口 。 

@ sendmail_from 设置 将 在 邮件 客户 "m: 的 邮箱 地 址 。 

图 sendmail_path 设置 发 送 邮 件 的 路 径 。 UNIR Aa 须 设 置 ， 采 用 /usr/sbin/sendmail 格式 。 

© mail.force extra parameters amg ^ 


3， 网 上 搜索 SMTP X „X XX. 


(1) (EHE HIR RO PREX PHP 使 用 s cket 实 闪现 邮件 发 送 的 SMTP 类 。 分 析 其 
/websh M is H3& F. SMTP 类 图 如 图 8.8 所 示 。 











中 的 代码 , 以 文件 名 smptinc php 1 














smpt 类 KR 2 

public Ssmtp. port: /端口 号 AS public Sdebug; /调试 状态 

public $time_out; 超时 时 间 public Sauth; 是 否 要 验证 身份 
public Shost name; /主机 名 称 public Suser; 用 户 名 

public Slog file; /日 志文 人 public $pass; 密码 

public Srelay host; SMTP 主机 rivate $sock; — //Socket 

. construct() smtp ok() 分 析 SMTP 响应 内 容 
sendmail() smtp_putcmd(0) /发 送 指 定 命令 

smtp. send() smtp. error() 在 日 志 中 ii 
smtp_sockopen() 连接 Socket log_write() 在 日 志 上 u 
smtp. sockopen relay() /根据 现 SMTP 连接 Socket strip comment() /去 掉 接 收 方 地 址 * " 的 多 
smtp. sockopen mx() 根据 地 址 查找 mx 记录 ,并 连接 | RAR 

Socket get. address() 处 理 邮 件 地 址 





件 头 及 正文 内 容 smtp. debug() 调试 时 输出 相关 信息 
束 标志 


smtp message() 
smtp. eom() 














图 8.8 SMTP 类 图 
(2) 在 smpt 类 之 后 ， 编 写 发 送 邮件 函数 sendmail0， 保 存 文件 。 
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—./ / smtp 类 
function sendmail($mailto, $mailsubject, $mailbody, $mailtype- "text/html", 
Sattachmentlist { 
$smtpserver-"smtp.163.com"; //SMTP 服务 器 
$smtpserverport=25; //SMTP 服务 器 端口 
$smtpusermail-"wuyaadmin8163.com";  //SMTP 服务 器 的 用 户 邮箱 
$smtpemailto-" wuyaadmin @163.com"; // 发 送 给 谁 





$smtpuser-" wuyaadmin @163.com"; / / SMTP 服务 器 的 用 户 账号 
$smtppass-"111111111"; / / SMTP 服务 器 的 用 户 密码 


$smtp-new smtp ($smtpserver,$smtpserverport,true,$smtpuser, $smtppass); 
// 这 里 面 的 true 是 表示 使 用 身份 验证 , 否则 不 使 用 身份 验证 
$smtp-»debug-TRUE; // 是 否 显 示 发 送 的 调试 信息 
$smtp-»sendmail($mailto, $smtpusermail, $mailsubject, $mailbody, 
$mailtype,S$attachmentlist); 
) 





y 

^^ PHP 编 码 
1. 发 送 订单 处 理 消息 
代码 文件 : order_p.php 


(1) 在 Dreamweaver 中 ， 打 开 文 件 /webshop/order_p.phps 
(2) 单 击 “代码 ”标签 ,% 切 换 到 “代码 ”视图 并 插入 如 下 代码 。 





.…// 设 置 订 单 生成 反馈 入 息 之 后 | 
require ohce ('includeNsmpt.inc.php'); 
$sendTo-Semaill; // 这 个 标准 的 电子 邮件 地 址 用 于 指明 邮件 要 发 送 到 哪里 
$MsgSbbject=" 订 单 "; // 这 是 电子 邮件 消息 的 主题 
$sendHeader="From: adminster@wuya.com \r\n"; // 电 子 邮 件 头 标 
$MsgBody-$msg; // 这 是 消息 的 主体 ， 没 有 大 小 限制 


if(8!mail($sendto, $MsgSubject, $MsgBody, $sendHeader) 
// 若 使 用 mail 函数 发 送 不 成 功 
sendmail($sendto, $MsgSubject, $MsgBody, "text");  ”// 使 用 SMTP 类 发 送 


LAN 注 电子 邮件 头 标 : 电子 邮件 消息 像 Web 页 面 一 样 具有 头 标 ， 遵 循 电子 邮件 标准 (RFC 822)， 可 以 
修改 发 信人 的 姓名 和 电子 邮件 地 址 。 大 多 数 电子 邮件 服务 程序 要 求 有 符号 \r( 回 车 )。 
(3) 保存 文件 。 
2. 发 送 推荐 图 书 消息 
代码 文件 ，com_mail.php 





(1) 在 Dreamweaver 中 ， 新 建 PHP 文档 。 
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(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 输 入 如 下 代码 。 


<?php 
…// 针 对 每 个 订单 中 用 户 
require_once ('.\include\smpt.inc.php'); 
$sendTo=$email; // 这 个 标准 的 电子 邮件 地 址 用 于 指明 邮件 要 发 送 到 哪里 
$MsgSubject=" 推 荐 图 书 "; // 这 是 电子 邮件 消息 的 主题 
$sendHeader -"From: admin«adminster&8wuya.com» Mr Nn"; 


// 电 子 邮 件 头 标 ， 指 明 消息 的 来 源 

















$sendHeader . MIME-Version: 1.0\n";  // 电 子 邮件 头 标 ， 指 明 消 息 使 用 MIME 类 型 
$sendHeader . -"Content-type: text/html;charset-utf8Nn"; // 电 子 邮 件 头 标 
$MsgBody=" 
<html> 
<head><title>HTML message </title></head> 
<body> 
& // 显 示 每 本 推荐 图 书 的 列表 
<body> d 
<html>"; // 这 是 消息 的 主体 ， 包 含 了 文本 和 BTML 标记 


if(8!mail($sendto, $MsgSubject, $MsgBody, $sendHeader) 
// 若 使 用 mail 函数 发 送 不 成 功 
sendmail(Ssendto, $MsgSubject, SMsgBody, "html"); // 使 用 SMTP 类 发 送 ?> 





LN 注 电子 邮件 头 标 : 除了 指明 消息 的 来 源 外 ， 还 指明 了 消 筷 使 用 MIME 类 型 及 指定 邮件 的 
Content-type 是 HTML、 编 码 是 utf8。 


Sret 、 
MIME( 多 用 途 互 联网 邮件 扩展 ) 


在 互联 网 发 展 的 早期 ， 电 子 邮 件 消息 只 包含 普通 文本 ， 而 这 个 扩展 也 许 电子 邮件 包含 谋 入 消息 
文本 的 HTML 丢 记 、 图 像 、 链 接 、 图 形 、 徽 标 及 附件 。 当 今 发 送 的 大 多 数 电子 邮件 都 使 用 MIME. 

包含 不 同类 型 内 容 的 电子 邮件 被 称 为 “组 合 ”MIME 消息 。 在 发 送 这 种 类 型 的 电子 邮件 时 ， 文 
件 类 型 和 编码 类 型 是 经 过 MIME 头 标 发 送 的 。 文 件 类 型 如 表 8.9 所 示 . 





表 8.9 文件 类 型 
类 
















型 




















text/plain | .txt | 普通 文本 类 型 application/x-shockwave-flash | .swf fla | Flash 文件 
text/javascript | js | JavaScript 文件 | application/pdf. | .pdf | PDF 文件 
text/html | .htm .html | HTML 文件 application/octet-stream | exe | 应 用 类 型 
text/css | .CSS | CSS 样式 表 文件 | video/avi | „avi | AVI 文件 
image/gif | .gif | GIF 图 像 文 件 audio/wav | .wav | 波形 文件 
image/jpeg | | JPEG 图 像 文件 | mutitpar/mixea | | 混合 型 








application/zip 压缩 文件 








(3) 把 文档 以 com_mail.php 为 文件 名 保存 在 /admin 文件 夹 下 。 
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8.53 PHP 发送 电子 邮件 的 方式 
PHP 可 以 通过 mail 函数 发 送 电子 邮件 ， 也 可 以 使 用 SMTP 类 。 
l. mail()i&4k 
bool mail(string to,string subject,string message[,string additional headers [,string additional parameters]]) 
S un 


函数 返回 值 : 如 果 检 查 到 有 邮件 发 送 ， 则 返回 TRUE; 和 否则， 返回 FALSE。 各 参数 的 含义 如 下 。 























O to: 邮件 接收 者 ， 如 果 要 给 多 用 户 发 送 ， 可 以 用 过 号 分 隔 。 入 
Q subject: 邮件 主题 。 Po K 
G message: 邮件 内 容 。 QN 
图 additional headers: 邮件 头 部 信息 。 AN \ 
© additional parameters: 附加 参数 。 : 

X 


ÁNA 这 里 的 邮件 发 送 成 功 只 是 说 明 STMP 服务 器 接 了 这 份 邮件 ,但 并 不 代表 邮件 已 发 送 到 了 接收 
者 的 邮箱 。 如 在 没有 连接 Intenet 时 7 会 出 现 错误 信息 息 : 
邮件 转发 失败 ! From: alilianf@loi loseom /To:alilianf@citiz.net Time:16:02:35 


2，PHP 发 送 电 子 邮件 消息 NS 


PHP 发 送 电子 邮件 消息 有 EX HAM: X 
(1) 文本 类 型 ， 如 案例 中 的 /webshop/order KC 
(2) HTML 类 型 六 如 案例 中 的 /admin/com 1 P php. 
GG) 包含 附件 的 消息 。 案 例 中 adminyEamLmailphp 可 以 通过 附件 发 送 图 书 封面 。 


8-5 ”发 送 包 f ^T 件 的 消息 
«?php 
// 针 对 每 位 订单 用 户 
$FilePathName-"tmp/"; // 定 义 本 地 文件 系统 上 一 个 文件 的 完整 路 径 
$FileName-"tmp/".$book pic; // 把 图 书 封面 作为 附件 的 文件 名 
$FileHandle-fopen($FilePathName,"rb");  // 以 二 进 制 只 读 方式 打开 文件 
$FileContent=fread ($FileHandle, filesize ($FilePathName)); 


// 读 取 图 像 内 容 ， 把 它 保存 在 变量 中 








fclose ($FileHandle); // 关 闭 文件 句柄 

$AttachmentData-chunk split(base64 encode($FileContent));  // 编 码 文件 内 容 
~…// 显 示 每 本 推荐 图 书 的 列表 

/ /参数 设 置 


$sendTo=$email; 

$Msgsubject=" 包 含 附件 邮件 信息 "; 

$sendHeader-"From: admin<adminster@wuya.com>\r\n"; 
$sendHeader.-"MIME-Version: 1.0\n";  // 电 子 邮 件 头 标 ， 指 明 消 息 使 用 MIME 类 型 
$sendHeader.="Content-Type:multipartt/mixed;boumdary=\ "--abcdefgh--\ ""; // 定 界 符 
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$MsgBody- " // 第 一 部 分 

--abcdefgh-- 

Content-type: text/html;charset-utf8  // 使 用 HTML 和 编码 标准 是 utf8 
Content-Transfer-Encoding:8bit\n"; // 使 用 的 传输 编码 方式 的 标准 是 8 位 


$MsgBody.-$MsgHTMLPart; / [3 HTML 部 分 添加 到 消息 主体 
$MsgBody.-" // 第 二 部 分 
--abcdefgh- 


// 使 用 二 进 制 数据 类 型 


Content-type: application/octet-stream; name-V"".$FileName. "A" 


Content-Transfer-Encoding: base64 // 典 型 的 二 进 制 编码 方式 是 base64 
// 告 诉 邮件 阅读 器 这 是 附件 
Content-Disposition: attachment; filename=\"".$FileName."\"\n\n"; 
$MsgBodym.-$AttachmentData; // 添 加 mail 函数 发 送 的 邮件 信息 
// 信 息 尾 
$MsgBody.-"An--abcdefgh--Wn";  // 使 用 于 开始 和 结束 样 的 定 界 符 结束 消息 
if (@!mail ($sendto, $MsgSubject, $MsgBodym, $se, ) ) // 发 送 电 子 邮 件 函 数 
// 使 用 SMTP 类 发 送 rS» 
tml",$AttachmentData); 


sendmail ($sendto, $MsgSubject, "Sy 
?> 


^ 
FINGER O 编码 文件 内 容 : 为 了 符合 RFC2045 WSs, 把 文件 转化 为 base64 编码 的 文本 之 后 ,文件 
数据 被 分 害 为 较 小 的 数据 块 。 chuRSSHlit() 函 数 会 将 76 个 字符 插入 一 个 结束 符 (默认 是 Win)， 返 
回 新 的 字符 串 而 不 会 修改 原 字 符 事 SA 
O 定 界 符 : 这 个 消息 包 全 多 个 分 . LADRAR AADA. 应 用 分 割 两 部 分 
的 定 界 符 被 设置 为 --abcdefgh--。 定 界 符 两 侧 都 要 有 双 连 字符 ; 用 户 端的 电子 邮件 阅读 器 利用 定 
界 符 判 断 消息 的 哪 部 分 是 附件 ， 哪 部 分 是 普通 文 机 
Q 第 一 部 分 $\ 发 送 界定 符 ， 这 部 分 是 HITNIL 
@ 第 二 部 入 六 发 送 界定 符 ， 这 部 分 天 附件 、 
NO j 


S 预备 知识 


8.4.1 ”正则 表达 式 简介 


PHP 支持 两 种 类 型 的 正则 表达 式 : POSIX 样式 和 Perl 样式 ， 每 种 类 型 都 有 一 组 函数 。 

POSIX 扩展 正则 表达 式 支 持 字符 串 匹 配 、 判 断 、 条 件 子 模式 等 复杂 的 字符 串 操作 ， 函 
数 名 以 ereg_ 为 前 级 ， 与 UNIX 的 egrep 命令 相似 ， 其 优点 在 于 兼容 旧版 本 的 PHP， 缺 点 是 
速度 慢 、 主 要 用 于 文本 数据 ， 不 如 Perl 样式 灵活 。 

与 Perl 兼容 的 正则 表达 式 PCRE 类 似 于 Perl， 支 持 较 新 的 特性 ， 如 引用 、 捕 获 、 后 测 、 
前 测 ,能 安全 用 于 二 进 制 模式 .函数 名 以 preg 为 前 级 ,PHP 必须 支持 PCRE(Perl Compatible 
Regular Expression) 库 ， 而 且 要 安装 到 Web 服务 器 上 。 从 如 图 2.34 所 示 的 脚本 phpinfo0 测 
试 界 面 中 可 以 了 解 是 否 启动 了 PCRE。 


8.4 正则 表达 式 
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2 实现 过 程 


8.4.2 ”常用 表单 项 验证 

l. 用 户 名 和 密码 验证 

在 注册 和 255 ARA IG 行 约束 ， 要 求 用 户 ID 是 包含 字母 和 数字 
且 以 下 划 线 母 开始 长 度 为 4 一 30 个 字符 串 。 密 码 是 由 字母 与 数字 组 成 且 长 度 为 6 一 20 
的 字符 串 。 在 applycard. 中 第 一 次 输入 用 户 ID， 需 要 在 applyphp 中 EH P ID 的 合法 
性 。 也 可 能 以 “ 跳 过 ”购书 卡 在 applysrc.php 中 设置 用 户 名 和 密码 ， 需 要 在 success.php 验 
证 它们 的 合法 性 。 其 余 表单 中 输入 的 用 户 ID 和 密码 可 与 数据 库 中 的 数据 验证 。 另 外 ,在 会 
员 管 理 中 ， 用 户 也 会 修改 密码 ， 需 要 

(1) 在 Dreamweaver 中 ， 打 开 站 点 的 register 目录 下 的 文件 apply,php。 

(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 添 加 如 不 代码 


















证 。 





if ($select==" 跳 过 ") ( 





(3) 保存 文件 。 
(4) 在 Dreamweaver 中， 打开 站 点 的 register 目录 下 的 文件 success.php。 
(5) 单 击 “ 代 码 亿 标签 ， 切 换 到 “代码 ”视图 ,添加 如 下 代码 。 


PR $ POST[ Siepen 





(6) 保存 文件 。 

(7) 对 member 文件 夹 下 的 update.php 作 同 样 的 修改 

2. 电子 邮箱 验证 

一 个 电子 邮箱 地 址 一 般 由 3 部 分 组 成 : 用 户 名 、@、 域 名 。 对 用 户 名 的 约束 与 “用 户 名 和 密 
双 验 证 ”中 的 用 户 名 验证 类 似 ,但 对 长 度 没 有 限制 。 域名 可 以 是 多 级 的 ， 至 少 包含 二 级 ， 即 包含 
一 个 “.” 分 隔 符 。 用 户 设置 电子 邮箱 的 地 方 有 多 处 ， 可 先 写 一 个 函数 ， 在 需要 的 地 方 调用 它 。 
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(1) 在 Dreamweaver 中 ， 打 开 站 点 的 register 目录 下 的 文件 sys_confinc。 


Q) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 在 ?> 前 添加 如 下 代码 。 





function isEmail(Sstr)í 
$pattern-"/^[N-Na-zA-Z] [N-Nw] *8 [NWN7] t (N. [Nw] t) *$"; 
if (ereg ($pattern, $str)--1) return true; 


else return false; 





?2 


(3) 保存 文件 。 
(4) 在 Dreamweaver 中 ， 打 开 站 点 的 register 目录 下 的 文件 success.php。 
(5) 单 击 “ 人 代码” 标签 ， 切 换 到 “代码 ”视图 ， 添 加 如 下 代码 。 


include ("sys conf.inc"); 







"输入 的 电子 





(6) 保存 文件 。 
(7) 对 webshop 目录 下 的 文件 config.inc.php 和 order. p.php 作 同 样 的 修改 
另外 ， 对 用 户 输入 的 邮编 闪电 话 号 码 的 合法 性 也 可 作 类 似 的 验证 。 


function isEmail(SStr)( .. // 见 本 页 上 方 8 一 12 行 
function isPost ($str)( 
Spattérn-"/^([1-9] (1)) ([0791(57) $7"; /7 定义 邮编 的 正则 表达 式 
if(preg match ($pattern, $str)--1) return true; 
else return false; 
) 
function isPhone($str)( 
$pattern-"/(^0[1-9] (2,3)) \- ([1-9] (8)) $/"; // 定 义 电话 号 
if (preg_match ($pattern, $str)--1) return true; 
else { 
Spattern-"/(^1[3,5,8] {1}) ([0-9] {9})$/";// 定 义 电话 号 码 的 正则 表达 式 2 
if (preg_match ($pattern, $str)--1) return true; 
else return false; 





的 正则 表达 式 1 





3. 图 书 查询 验证 
在 图 书 搜索 查询 时 ， 需 要 用 户 输入 查询 条 件 ， 特 别 是 日 期 ， 必 须 符 
的 格式 ， 因 此 需要 验证 。 在 leftphp 中 使 用 了 正则 表达 式 做 了 合法 性 
























以 这 样 做 : 


d 


qx 


409 
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(1) 在 Dreamweaver 中 ， 打 开 站 点 的 根 目 录 下 的 文件 search. key.php. 
(2) 单 击 “代码 ”标签 ， 切 换 到 “代码 ”视图 ， 在 最 后 添加 如 下 代码 。 


if($cond--"pub date")( 
$pattern="/^\d{4}\- [0-1]? [0-9] \- [0-3]? [0-9]$/"; ”// 定 义 日 期 的 正则 表达 式 
if (preg match ($pattern, $keys)==0) { 
echo "<script type='text/javascript'>window.alert(' 输 入 的 日 期 格式 
合法 ! ') ;</script> "; 
echo "<meta http-equiv-'Refresh' content='0;url=main.php'>"; 
} 
$serach-"$cond»-$27$keys$27"; 





(3) 保存 文件 。 
4. 关键 字 着 色 
使 用 正则 表达 式 可 以 将 页 面 中 所 有 提供 站 内 搜索 的 关键 字 加 上 颜色 以 示 强 调 。 
首先 确定 要 查找 的 关键 字 $keyword， 接 着 需要 获得 要 输出 到 页 面 的 HTML 标记 ， 然 后 
ied 正则 表单 的 是 替代 函 ii REEF 4) UII IE-«font color="#0000FF">$keyword<font> 标 
， 使 得 关键 字 显示 为 蓝 色 
(1) 在 Dreamweaver 5» 打开 站 点 的 webshop 目录 下 的 文件 book_show.php。 
(2) 单 击 “ 代 码 ” 标 签 ， 切 换 到 “代码 ”视图 ， 在 最 前 和 最 后 添加 如 下 代码 。 
<?php | 
Skeyword-"PHP"; | 1 
$color-"«font color-'£0000FE'»". Co "«/font»"; 
ob start(); 17/ 开 始 对 输出 内 容 的 缓存 
X/ 这 里 是 book_show.php 
$str-ob get contents () ; // 获 取 当 前 页 面 要 输出 的 全 部 内 容 
$str-preg replace("/".$keyword."/",S$color,$str); 
ob end clean(); // 清 除 原来 缓存 的 内 容 
echo $str; 
?2 








(3) 保存 文件 。 


cm 
(ss 


8.4.3 ”正则 表达 式 的 法 则 
1. 正则 表达 式 的 语法 


正则 表达 式 的 语法 与 Perl 类 似 ，PHP 支持 的 Perl 样式 正则 表达 式 语法 中 包含 的 元 字符 、 
字符 集 和 修正 符 。 其 中 元 字符 如 表 8.10 所 示 。 
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表 8.10 正则 表达 式 中 的 特殊 字符 








字 符 类 匹配 对 象 
行 首 或 字符 串 开始 ， 用 在 [] 中 则 表示 “排除 ” 
行 尾 或 字符 串 末 尾 


定 界 字 符 





单词 边界 





非 单词 边界 





字符 串 开始 





FERRE 





单个 字符 


单个 字符 和 数字 一 元 符号 


除 换行 符 外 的 任 站 








[a-zA-Z0-9] 





集合 中 任意 单个 字符 








[^a-zA-Z0-9] 


S+ 


不 在 集合 中 任意 单个 字符 

数字 相当 于 [0-9] 

上 数字 相当 于 [029] 

单词 字符 个 相当 于 [A-Za-z0-9] 

上 单词 字符 ， 相 当 于 [^A-Za-z0-9] 
相当 于 [vefwmvet] 

PTF HIH TFM efnt] 






































Esc 键 
空 自 字符 iiu 
RITR 
回 车 符 
Tab 制 表 符 
空 字符 
字母 $ 出 现 0 次 或 1 次 
重复 字符 FES 出现 0 次 或 多 次 
字母 S 出 现 1 次 或 多 次 
分 组 字符 (abc) ER Mae id zi 样式 — 
S{m,n} 字母 S 至 少 出 现 m 次 ， 最 多 不 超过 mn 次 
(string) 用 于 反 引 用 
M 或 S1 第 一 级 小 括号 
记忆 字符 E 
\2 :X$2 第 二 级 小 括号 
\3 sk$3 第 三 级 小 括号 
(x) 匹配 x 单 记忆 这 个 匹配 


确定 性 前 测 和 后 测 








x(?=y) 


只 匹配 后 面 跟着 y 的 x 





xy) 





只 匹配 后 面 没有 跟着 y 的 x 





"E 


was|were|will 





匹配 一 个 was 或 were £X will 


/ 
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Q 


LN 注 (D 定 界 字符 . 表示 内 部 的 内 容 是 一 个 正则 表达 式 ， 任 何不 是 字母 、 数 字 或 反 针线 (的 字符 都 
可 以 作为 定 界 符 。 如 果 作 为 定 界 符 的 字符 必须 被 用 在 表达 式 本 身 中 ， 则 需要 用 反 儿 线 转 义 。 自 
PHP 4.0.4 起 ， 也 可 以 使 用 Perl XU&690. (). [fec 匹配 定 界 符 。 

(2) 分 组 字符 。S{m,n} 其 内 数字 可 以 简化 ， 如 S{10} 表 示 匹 配 重复 10 次 的 字母 S; S{3,} 表示 
匹配 重复 3 次 ( 含 ) 以 上 的 字母 S. 

(3) 以 下 两 个 字符 具有 特殊 作用 。 

O whh: 十 六 进 制 ， 可 以 表示 所 有 字符 ， 包 括 特殊 字符 ， 如 Wx0d 表示 \r。 

®© \ddd: 八进制 ， 与 十 六 进 制 数 用 法 类 似 . 

(4) 括号 对 。 正则 表达 式 中 括号 的 含义 各 不 相同 。 

O 中 括号 对 []: 表示 一 个 “组 "， 组 中 元 素 的 关系 是 “或 "， 可 用 “-" 表 示 一 个 范围 。 

© 花 括 号 对 {}: 表示 一 种 明确 的 限定 符 可 以 限定 前 面 出 现 的 最 多 和 最 少 次 数 。 

图 小 括号 对 {}: 小 括号 对 表示 的 是 子 匹配 ， 在 整体 匹配 完成 后 ， 表 达 式 还 将 进行 子 匹配 ， 并 
且 允 许 使 用 谈 套 . f 


修正 符 是 一 组 被 写 在 界定 符 外 部 “特殊 字符 ”， 表示 更 加 严格 地 限制 匹配 ， 如 表 8.11 所 示 。 
表 8.11 正则 表达 式 中 的 修正 符 

















* # LEE 
i 忽略 大 小 写 
m 多 行 
s we 
x 忽略 表 
e 仅 用 、 双 引号 等 PHP 代码 字符 
A 从 头 匹 配 ， 限 定 只 能 从 字符 串 头 部 开始 匹配 二 





让 $ 只 匹配 结束 符 ， 挟 认 情况 下 $ 还 匹配 行 结 琳 符 
加 强 分 析 ， 当 改变 的 被 多 次 使 用 时 ， 使 用 该 修正 符 可 以 提高 效率 
非 贪 禁 匹 配 Y 

使 用 扩展 功能 
utf8 匹配 ， 正 则 表达 式 被 视 为 字符 串 来 匹配 
在 POSIX 扩展 中 使 用 的 正则 表达 式 分 简单 匹配 和 集合 匹配 两 种 情况 。 

(1) 简单 匹配 。 用 ^ 代 表 字 符 串 的 开头 ，$ 代 表 结尾 ， 定 义 一 个 样本 。 只 有 开头 或 结尾 与 
样本 匹配 的 字符 串 才 是 匹配 的 ， 如 示例 8-6 所 示 。 





cjajo 





ex 
[ei 




















示例 8-6 ”简单 匹配 的 例子 


<?php 
$syl="^php"; // 定 义 以 php 开头 的 样本 
$sy2-"language.$"; // 定 义 以 language .结尾 的 样本 


$bcl-"php is a language."; // 符 合 两 个 样本 
$bc2-" php is a language.";  // 符 合 $sy2 样本 ， 不 符合 $syl 
$bc3="php is a language. "; // 符 合 $syl 样本 ， 不 符合 $sy2 
?» 
(2) 集合 匹配 。PHP 内 建 了 一 些 样本 ， 如 表 8.12 所 示 。 建 立 字符 的 集合 来 提供 的 “ 样 
本 ”可 视 为 一 个 “单个 ”的 字符 比较 ， 如 表 8.13 所 示 。 
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表 8.12 PHP 内 建 的 样本 
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样 本 样 本 符合 条 件 
[[:alpha:]] [[:upper:]] 任何 大 写 英文 字母 符号 
[[:digit:]] 号 [[lower]] | 任何 小 写 英文 字母 符号 
[[:alnum:]] 任何 英文 字母 或 数字 符号 [[:punct]] 任何 英文 标点 符号 





[[:space:]] 


空格 符号 任何 十 


[[:xdigit]] 





表 8.13 ”建立 字符 的 集合 来 提供 “单个 ”字符 的 比较 


六 进 制 数字 








样 本 符合 条 件 范例 
[a-z][0-9] 车 含有 如 a0、k6、d9 等 的 字符 串 ， 则 符合 Ca02, ijk9v 
^[a-z][0-9]$ 小 写字 二 数字 结尾 的 两 个 a0, b6, c3, vl 








^[a-z]{3}$ 由 匹配 


明成 的 包含 











^[a-z]{3,6}$ 由 匹配 学 

^[a-z](3.]$ 由 匹配 日 成 的 包含 3 个 字符 以 上 的 
^[a-z]*$ 旧 成 的 包含 1 个 

^[a-z]*$ ILIA Gr 0 





2， 正 则 表达 式 的 相关 函数 







abc, def, ghi 
abc, abcd, abcde 
abcdefg, cab 
a, ab, abc, fbcd 
ba, ab, abc 





与 Perl 兼容 语法 的 正则 表达 式 函 数 库 (PCRE) 中 包含 的 函数 如 表 8.14 所 示 。 
表 8.14 与 Perl 兼容 语法 的 正则 表达 式 函 数 库 (PCRE) 中 包含 的 函数 


Go A 


string preg. quote(string str [, string delimiter]) 


int preg match(string pattern, string subject [, array 
matches [, int flags]]) 

int preg match all(string pattern, string subject, 
array matches [, int flags]) 


x 能 
在 字符 串 str 中 的 特殊 字符 (+* ?[^]$(){}=!< 
7] :) 前 而 加 上 反 斜 线 。 可 选 参数 delimiter， 指 定 被 转 
义 的 字符 
(1) 在 subject 中 搜索 所 有 与 pattern 匹配 的 内 容 并 将 
结果 以 flags 指定 的 顺序 放 到 matches 中 。 
(2) preg_match() 在 第 一 次 匹配 之 后 将 停止 搜索 ; 
preg_match_all0) 会 一 直 搜索 到 subject. 的 结尾 处 








mixed preg_replace(mixed pattern, mixed replacement, 
mixed subject [, int limit]) 
mixed 


preg replace callback(mixed pattern, 


callback callback, mixed subject [, int limit]) 


(1) 在 subject 中 搜索 pattern 模式 的 匹配 项 并 替换 为 
Teplacement。 
(2) 当 指 定 limit 时 , 仅 替换 limit 个 匹配 ; 当 省 略 limit 
或 者 其 值 为 一 1 时 ， 所 有 的 匹配 项 都 会 被 替换 数组 。 
(3) preg replace callback() 不 是 提供 参数 replace 
ment， 而 是 指定 一 个 函数 callback 








array preg. grep(string pattern, array input) 


返回 一 个 包括 input 数 组 中 与 给 定 的 pattern 模式 相 匹 
配 的 单元 的 数组 





array preg split(string pattern, string subject [, int 
limit [, int flags]]) 








(1) 返回 一 个 包含 subject 上 
分 割 的 子 串 的 数组 。 

(2) 当 指定 limit 时 , 最 多 返回 limit APP, 当 limit = 
二 1 时 ， 没 有 限制 ， 可 以 用 来 继续 指定 可 选 参数 flags 





1 与 pattern 匹配 的 边界 所 
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LN i£ preg_match() 中 的 flags: 


PREG OFFSET CAPTURE: 对 每 个 出 现 的 匹配 结果 同时 返回 其 附属 的 字符 串 偏 移 量 。 

(2) preg_match_all() 中 的 flags: 还 包含 

PREG PATTERN ORDER: 对 结果 排序 使 Smatches[0] 为 全 部 模式 匹配 的 数组 ，Smatches[]1] 为 
第 一 个 括号 中 的 子 模式 所 匹配 的 字符 囊 组 成 的 数组 ， 依 此 类 推 . 

PREG SET ORDER: 对 结果 排序 使 Smatches[0] 为 第 一 组 匹配 项 的 数组 ，$matches[1] 为 第 二 组 
匹配 项 的 数组 ， 依 此 类 推 . 

但 把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合 起 来 用 没有 意义 。 

© preg split() 49 flags: 可 以 是 下 列 标记 的 任意 组 合 (用 按 位 或 运算 符 | 组 合 )。 

PREG SPLIT NO EMPTY: 只 返回 非 空 的 成 分 。 

PREG SPLIT DELIM CAPTURE: 定 界 符 模式 中 的 括号 表达 式 也 会 被 捕获 并 返回 。 

PREG SPLIT OFFSET CAPTURE: 对 每 个 出 现 的 匹配 结果 也 同时 返回 其 附属 的 字符 串 偏 移 
量 。 注意 ， 这 改变 了 返回 的 数组 的 值 ， 使 其 中 EPIGUDR A RUN 其 中 第 一 项 为 匹配 字 
符 串 ， 第 二 项 为 其 在 subject 中 的 偏 移 量 。 


正则 表达 式 函数 库 (POSIX 扩展 ) 中 包含 的 函数 如 表 ais pon. 


string sql. regcase(string Sstring) 


array split(string Spattern, string Sstring b 


int Slimit]) 


array spliti(string Spattern, string Sstánig L 


int Slimit]) 


bool ereg(string $pattern, string $string [, 


815 nts «ras 


E 5 rx 能 

把 string: RON 不 区 分 大 小 写 的 匹配 的 正则 表达 式 

(Q0) 返回 一 个 字符 串 数组 , 每 个 单元 为 string. 经 样本 pattern 
看 为 边界 分 割 出 的 子 串 < 

(D) ME limit 时 ， 返 回 的 数组 最 多 包含 limit 个 单元 ， 而 
其 后 一 个 单元 包 合 string 中 剩余 的 部 分 。 

(3) spliti 0 不 区 分 大 小 写 ，split0 区 分 大 小 写 


(1 "7 string 匹配 样本 pattern 时 ， 返 回 TRUE. 





array Sregs]) 2 T2 

Te ANON " dc Q) 数组 参数 regs 可 省 略 
bool eregi(string. Spattern, string $string [. G) 函数 eregi0 不 区 分 大 小 写 ， 函 数 ereg0 区 分 大 小 写 
array $regs]) 


string ereg_replace(string $pattern, string 


Sreplacemei 


string eregi replace(string $pattern, string 


Sreplacemei 


(1) 在 字符 串 string 中 ， 用 样本 pattern 取代 字符 串 
replacement. 


(2) eregi_replace0 不 区 分 大 小 写 ，ereg_replace0 区 分 大 小 写 


nt, string Sstring) 


nt, string Sstring) 

















使 用 正则 表达 式 函 数 库 (PCRE 扩展 ) 对 电子 邮箱 的 验证 如 示例 8-7 所 示 。 














示例 8-7 H 
<?php 


扩 箱 验证 


$email="ABC@mail.net"; 
if (preg match("/^[[:alnum:]]+@[[:alnum:]]+\.[[:alnum:]]+/",$email)) echo" 


正确 的 电子 邮箱 地 址 "; 


else 





echo "不 正确 的 电子 邮箱 地 址 "; 
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通过 学 习 本 章 案例 ， 对 PHP 动态 网 站 中 的 图 像 处 理 和 电子 邮件 处 理 有 所 认识 ， 主 要 包 
括 以 下 几 点 。 
(1) PHP 图 像 处 理由 图 像 函数 实现 ， 这 里 主要 介绍 了 GD 库 中 的 相关 函数 ， 实 现 了 注 
肌 验 证 码 图 像 生成 和 验证 功能 。 
Q) 利用 GD 库 中 的 相关 函数 还 可 以 对 上 传 的 图 像 作 水 印 、 缩 略图 等 处 理 , 这 样 做 有 利 
于 对 图 像 实现 简单 的 版 权 保护 。 
(3) 文件 上 传 是 网 站 管理 中 常用 的 操作 。 限 定 上 传 文件 的 大 小 和 格式 可 防止 病毒 传播 
等 不 良 行为 。 

(4) 电子 邮件 处 理 是 与 客户 沟通 的 一 种 有 效 手段 。 通 过 电 过 
的 内 容 ， 如 订单 处 理 、 推 荐 信息 等 。 
(5) 字符 的 查找 和 替代 是 字符 串 操作 中 最 党 用 的 操作 。 jiena, 


ea 2452 AS 
(1) 分 析 文件 上 传 会 给 mne io 

































































Q) 利用 GD 库 能 对 图 像 做 哪些 
G) ES XS 


SATT | x y x? v^ 


项 目 8-1 RLA REE 事 正则 表达 式 ) 


项 目 目标 : 
(1) 演示 如 何 测试 用 户 输入 数据 的 格式 。 
(2) 演示 如 何 验证 邮箱 地 址 。 
步骤 : 
(1) 使 用 一 个 文本 编辑 器 ， 如 记事 本 ， 创 建 如 下 内 容 的 p8-1.php 的 文件 ， 上 载 到 服务 
器 上 ， 放 在 excise 目录 中 。 
<?php 
$pattern-$ POST['pattern']; 
$string-$ POST['string']; 
echo "«br/»«B»Ffjfh: «/B»&nbsp; $string"; 
echo "<br/><B> 正 则 表达 式 : «/B»&nbsp; $pattern"; 
if(get magic quotes gpc())( 
echo "<br/><br/> 注 意 引号 的 使 用 … "; 
$string-stripcslashes ($string); 


$pattern-stripcslashes ($pattern); 
echo "<br/><B> 字 符 串 : «/B»&nbsp; $string"; 
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(2) 将 下 面 的 HTML 文本 放 在 一 个 名 为 p8-1.html 的 文件 中 ， 和 
器 上 ， 放 在 与 文件 p8-1.php 相同 的 目录 中 。 





(3) 在 Web 浏览 器 上 , 访问 与 p8-1.html 相关 联 的 URL, 观察 执行 结果 (屏幕 截图 表示 )。 
(4) 在 文本 框 中 输入 文本 ， 单 击 “提交 ”按钮 ， 观 察 执行 结果 (屏幕 截图 表示 )。 

(5) 分 析 程序 代码 : 

CD 函数 get_magic_quotes_gpc0 调 用 的 作用 。 

@ 函数 stripcslashesO 调 用 的 作用 。 

(8) HTML 文件 中 pattern 文本 框 的 默认 值 的 正则 表达 式 。 


项 目 8-2 使 用 POP3 实现 一 个 简单 的 电子 邮箱 管理 器 
项 目 目标 : 
(1) 了 解 电子 邮件 的 工作 原理 。 


9, 
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(2) 使 用 面向 对 象 技术 设计 POP3 类 实现 电子 邮件 的 接收 。 
FR: 

(1) 上 网 搜索 电子 邮件 的 工作 原理 。 

(2) 上 网 搜索 并 下 载 POP3 类 的 相关 代码 。 

(3) 分 析 POP3 类 代码 , 并 编写 一 个 类 似 于 电子 邮件 客户 端的 在 线 邮 件 管理 器 来 接收 和 
管理 邮件 。 邮 件 管理 器 应 具有 以 下 4 个 基本 功能 。 

CD 以 邮件 标 头 的 形式 呈现 邮箱 中 的 所 有 邮件 。 标 头 包括 发 件 人 和 邮件 主题 , 还 可 能 包 
含 邮件 的 发 送 时 间 、 日 期 及 邮件 大 小 。 

© 用 户 可 以 点 选 标 头 ， 阅 读 相 应 邮件 。 

图 用 户 可 以 新 建 并 发 送 邮件 。 写 信 时 要 输入 收 件 人 地 址 、 邮 件 主题 和 邮件 内 容 。 

© 用 户 可 以 在 发 送 邮件 时 添加 附件 ， 也 可 保存 来 信 中 的 附件 * 
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